高 职高 专 计算 机 教学 改革 OOO 规划 教材 


动态 网 站 设计 与 制作 
JSP 


oh 9j E f 
Wk 策 李 娜 副 主编 


高 职高 专 计 算 机 教学 改革 新 体系 规划 教材 


动态 网 站 设计 与 制作 一 一 JSP 


孙 OX 策 F 娜 主编 


清华 大 学 出 版 社 
北京 


AST 


JSP(Java Server Pages) 是 一 种 动态 网 页 技术 标准 ,利用 这 一 技术 可 以 快速 构建 跨 平台 的 .先进 的 、 
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ISP 进行 动态 网 页 制作 的 相关 知识 。 共 分 为 五 章 , 主 要 内 容 为 JSP 概述 .Web 开发 基础 JSP 语法 JSP 
内 置 对 象 JSP 数据 库 应 用 等 。 本 书 采用 案例 式 教学 方法 进行 编写 ,以 实例 应 用 为 主 ,理论 够 用 为 度 。 
书 中 每 一 个 知识 点 的 结构 模式 为 “案例 的 提出 一 关键 分 析 一 源 代码 讲解 一 相关 知识 点 归纳 总 结 ”。 
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动态 网 站 设计 与 制作 一 一 JSP 课程 是 信息 专业 、 网 络 专业 、 物 联网 专业 、 
电子 商务 专业 \ 云 技术 专业 的 一 门 重要 的 技术 课程 。 这 门 课程 与 Java 课程 、 
静态 网 站 设计 课程 数据库 等 也 有 着 密切 的 联系 。 

从 目前 的 职业 岗位 需求 来 看 ,网 站 开发 工程 师 、Java 开发 工程 师 、 系 统 
维护 工程 师 ,数据 库 工程 师 、Web 工程 师 ,智能 硬件 云 平 台 系统 架构 师 \ 云 平 
全 软件 开发 工程 师 、 电 子 商 务 平台 开发 工程 师 、 系 统 架 构 师 等 职业 都 需要 掌 
PJSP 开发 技术 。 通 过 该 课程 的 学 习 使 学 生 能 够 加 深 对 于 动态 网 站 、Web 
应 用 编程 思想 和 技术 的 理解 与 掌握 ,为 学 生 将 来 从 事 相 关 工 作 葛 定 良好 的 
基础 。 该 课程 是 培养 基于 Web 开发 的 主要 支撑 课程 ,同时 也 能 培养 学 生 良 
好 的 编程 规范 和 职业 习惯 。 

JSP 是 快速 建立 跨 平台 的 动态 网 站 的 首选 方案 ,因为 JSP 拥有 以 下 几 个 
方面 的 技术 特点 。 

1. 适应 平台 。 适 合 大 多 数 的 操作 系统 平台 。 

2. 执行 效率 高 。 拥 有 Java 编程 语言 “一 次 编写 ,各 处 运行 ”的 特点 。 

3. 将 内 容 的 生成 和 显示 进行 分 离 。 

4. 可 重用 组 件 。 使 用 JavaBean 技术 或 EJB 组 件 , 来 执行 应 用 程序 所 要 
求 的 复杂 的 处 理 。 

5. 采用 标识 。 标 准 的 ISP 标识 能 够 访问 和 实例 化 JavaBeans 组 件 。 

6. 数据 库 连 接 。 连 接 数 据 库 的 技术 是 JDBC, 目 前 大 多 数 数据 库 系统 都 
带 有 ODBC 驱动 程序 ,所 以 Java 程序 能 访问 诸如 Oracle, Sybase, MS SQL 
Server 和 MS Access 等 数据 库 。 

本 书 所 使 用 的 开发 环境 : JDK 十 Tomcat 十 IE 或 其 他 类 型 的 浏览 器 。 

开发 工具 : MyEclipse+ Dreamweaver, 

目前 市 面 上 的 大 多 数 教材 ,大 多 有 两 个 方面 的 不 足 : 四 理论 知识 的 讲解 
书面 化 ,对 于 高 职 学 生 或 自学 的 社会 人 员 来 说 并 不 容易 理解 ; @ 示 范 举例 过 
于 简单 或 者 过 于 艰难 。 所 以 本 书 在 编写 思想 上 ,以 适应 高 职高 专 教学 改革 
的 需要 为 目标 ,以 企业 需求 为 导向 ,充分 吸收 国外 经 典 教材 及 国内 优秀 教材 
的 优点 ,结合 我 国 高 校 计算 机 教育 的 教学 现状 ,打造 立体 化 精品 教材 。 对 于 
高 职 学 生来 说 ,我 们 培养 的 不 是 能 够 发 明和 创造 代码 的 人 才 , 而 是 能 够 灵活 
使 用 快速 入 门 的 应 用 型 人 才 。 
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自 2013 年 本 书 的 相关 教学 资料 已 经 印刷 为 校内 讲义 ,经 过 三 年 的 使 用 、 调 整整 理 才 
完成 本 书 的 初稿 。 在 内 容 上 ,以 难度 适中 的 “程序 体验 ”为 载体 ,把 理论 知识 与 应 用 相 结 
合 , 每 个 程序 体验 都 有 相对 应 的 源 代码 说 明 ,无 论 是 高 职 学 生还 是 社会 自学 人 员 都 能 够 理 
解 和 掌握 每 个 题目 的 关键 点 ,并 且 安 排 了 阶段 性 的 拓展 项 目 和 课 后 练习 ,对 于 知识 的 活 学 
活用 有 很 大 帮助 。 

本 书 在 形式 上 ,利用 网 络 等 现代 化 手段 实现 立体 化 的 资源 共享 ,创建 了 专门 的 网 站 ， 
并 提供 题库 .素材 课件、 案例 分 析 等 内 容 ,实现 教师 和 学 生 在 更 大 范围 内 的 教学 互动 ,及 
时 解决 教学 过 程 中 所 遇 到 的 问题 。 

本 书 采用 案例 式 教学 方法 进行 编写 ,以 实例 应 用 为 主 , 理 论 够 用 为 度 。 教 程 中 每 一 个 
知识 点 的 结构 模式 为 “案例 的 提出 一 关键 分 析 一 源 代码 讲解 一 相关 知识 点 归纳 总 结 ”。 

本 书 由 天 津 轻 工 职业 技术 学 院 孙 莫 主 编 ,由 姚 策 和 李娜 担任 副 主 编 , 王 春 媚 、 张 润 华 、 
皮 琳 琳 和 海运 职业 学 院 李强 参 编 。 

本 书 专题 网 站 : http://211. 81. 40. 73/dz/dtwz/index. asp. 

因 时 间 有 限 ,本 书 难免 存在 朴 漏 之 处 ,和 敬 请 读者 批评 指正 。 
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1.1 JSP f$ jr 


JSP(Java Server Pages) Jé fH Sun Microsystems 公司 倡导 .许多 公司 参与 一 起 建立 的 
一 种 动态 网 页 技术 标准 。JSP 技术 类 似 于 ASP 技术 , 它 是 在 传统 的 网 页 HTML( 标 准 通 
用 标记 语言 的 子 集 ) 文 件 (*. htm, * . html) 中 插入 Java 程序 段 (Scriptlet) 和 JSP 标记 
(tag) ,从 而 形成 JSP 文件 ( * .jsp)。 用 JSP 开发 的 Web 应 用 是 跨 平台 的 , 既 能 在 Linux 
上 运行 ,也 能 在 其 他 操作 系统 上 运行 。 

动态 网 页 和 静态 网 页 的 根本 区 别 在 于 服务 器 端 返回 的 HTML 文件 是 事先 存储 好 的 
还 是 由 程序 即时 生成 的 。 静 态 网 页 文件 里 只 有 HTML 标记 ,没有 程序 代码 ,网 页 的 内 容 
都 是 事先 写 好 并 存放 在 服务 器 上 的 ; 动态 网 页 文件 不 仅 含 有 HTML 标记 ,而 且 还 含有 程 
序 代码 , 当 用 户 发 出 请 求 时 ,服务 器 由 动态 网 页 程序 即时 生成 HTML 文件 。 动 态 网 页 能 
够 根据 不 同 的 时 间 不 同 的 用 户 生成 不 同 的 HTML 文件 ,显示 不 同 的 内 容 。 


111 Jp 技术 特点 
JSP 是 快速 建立 跨 平 台 的 动态 网 站 的 首选 方案 ,因为 ISP 拥有 以 下 几 个 技术 特点 。 
1. 适应 平台 


由 于 JSP 的 脚本 语言 是 Java 语言 ,因此 它 具 有 Java 语言 的 一 切 特性 。 几 乎 所 有 平 
台 都 支持 Java, 所 以 JSP 十 JavaBean 几乎 可 以 在 所 有 平台 通行 无 阻 。 从 一 个 平台 移植 到 
另 一 个 平台 ,JSP 和 JavaBean 甚至 不 用 重新 编译 ,因为 Java 字 节 码 都 是 标准 化 的 ,与 平台 
无 关 。 


2. 执行 效率 高 


由 于 JSP 页 面 的 内 置 脚本 语言 是 基于 Java 的 ,而 且 所 有 的 JSP 页 面 都 被 编译 成 为 
Java Servlets. Br LA JSP 页 面具 有 Java 技术 的 所 有 优点 ,包括 健壮 的 存储 管理 和 安全 性 。 
作为 Java 平台 的 一 部 分 ,JSP 拥有 Java 编程 语言 “一 次 编写 ,各 处 运行 ”的 特点 。 
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24 ISP 第 一 次 被 请 求 时 ,JSP 页 面 转换 成 Servlet, 然 后 被 编译 成 . class 文件 ,以 后 ( 除 
非 页 面 有 改动 或 Web 服务 器 被 重新 启动 ) 再 有 客户 请 求 该 JSP 页 面 时 ,JSP 页 面 不 需 重 
新 编译 ,而 是 直接 执行 已 编译 好 的 . class 文件 ,因此 执行 效率 高 。 


3. 将 内 容 的 生成 和 显示 进行 分 离 


Hi ISP 技术 , Web 页 面 开 发 人 员 可 以 使 用 HTML 或 者 XML 标识 来 设计 和 格式 化 
最 终 页 面 。 生 成 内 容 的 逻辑 被 封装 在 标识 和 JavaBean 组 件 中 ,并 且 捆绑 在 脚本 中 ,所 有 
的 脚本 在 服务 器 端 运 行 。 巾 于 核心 逻辑 被 封装 在 标识 和 JavaBean 中 ,所 以 ,Web 管理 人 
员 和 页 面 设计 者 能 够 编辑 和 使 用 JSP 页 面 , 而 不 影响 内 容 的 生成 。 

在 服务 器 端 ,JSP 引擎 解释 JSP 标识 和 脚本 ,生成 所 请 求 的 内 容 , 并 且 将 结果 以 
HTML( 或 者 XML) 页 面 的 形式 发 送 回 浏览 器 。 这 既 有 助 于 作者 保护 自己 的 代码 ,又 能 
保证 任何 基于 HTML 的 Web 浏览 器 的 完全 可 用 性 。 


4. 可 重用 组 件 


绝 大 多 数 JSP 页 面 依赖 于 可 重用 的 、 跨 平台 的 JavaBean 或 EJB(Enterprise JavaBean) 
组 件 来 执行 应 用 程序 所 要 求 的 复杂 的 处 理 ,为 JSP 程序 的 开发 提供 了 方便 。 例 如 ,用 户 
可 以 将 复杂 的 处 理 程序 或 需要 重复 利用 的 程序 (如 对 数据 库 的 操作 ) 封 装 到 组 件 中 ,在 开 
发 中 可 以 多 次 使 用 这 些 组 件 , 提 高 了 组 件 的 重用 性 。 基 于 组 件 的 方法 加 速 了 总 体 开发 过 
程 , 并 且 使 得 各 种 组 织 在 他 们 现 有 的 技能 和 优化 结果 的 开发 努力 中 得 到 平衡 。 


5. 采用 标识 


Web 页 面 开发 人 员 不 会 都 是 熟悉 脚本 语言 的 编程 人 员 。JSP 技术 封装 了 许多 功能 ， 
这 些 功能 是 在 易 用 的 ,与 JSP 相关 的 XML 标识 中 进行 动态 内 容 生成 所 需要 的 。 标 准 的 
JSP 标识 能 够 访问 和 实例 化 JavaBean 组 件 ,设置 或 者 检索 组 件 属性 ,下 载 Applet. VAR TA 
行 用 其 他 方法 更 难于 编码 和 耗 时 的 功能 。 


6. 数据 库 连接 


Java 中 连接 数据 库 的 技术 是 JDBC ,Java 程序 通过 JDBC 驱动 程序 与 数据 库 相 连 , 执 
行 查询 、 提 取 数 据 等 操作 。Sun 公司 还 开发 了 JDBC 一 ODBC bridge, 利 用 此 技术 ,Java Fé 
序 可 以 访问 带 有 ODBC 驱动 程序 的 数据 库 , 目 前 大 多 数 数 据 库 系统 都 带 有 ODBC 驱动 程 
序 , 所 以 Java 程序 能 访问 诸如 Oracle, Sybase, MS SQL Server 和 MS Access 等 数据 库 。 

此 外 ,通过 开发 标识 库 ,JSP 技术 还 可 以 进一步 扩展 。 第 三 方 开发 人 员 和 其 他 人 员 可 
以 为 常用 功能 创建 自己 的 标识 库 。 这 使 得 Web 页 面 开发 人 员 能 够 使 用 熟悉 的 工具 和 执 
行 特定 功能 的 构件 来 进行 工作 。 

JSP 技术 很 容易 整合 到 多 种 应 用 体系 结构 中 ,以 利用 现存 的 工具 和 技巧 ,并 且 能 扩展 
到 支持 企业 级 的 分 布 式 应 用 中 。 作 为 采用 Java 技术 家 族 的 一 部 分 ,以 及 Java 2( 企 业 版 
体系 结构 ) 的 一 个 组 成 部 分 ,JSP 技术 能 够 支持 高 度 复杂 的 基于 Web 的 应 用 。 
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在 JSP 页 面 中 ,除了 普通 的 HTML 代码 .还 有 以 下 3 种 重要 的 组 成 部 分 : 脚本 元 素 、 
指令 和 动作 。 脚 本 元 素 用 来 使 Java 代码 可 以 直接 插入 Servlet; JSP 指令 用 来 从 整体 上 
控制 Servlet 的 结构 ; 动作 用 来 引入 现 有 的 组 件 或 控制 ISP 引擎 的 行为 。 比 较 常 见 的 
JSP 引擎 是 Tomcat, 把 支持 JSP 的 Web 服务 器 配置 好 以 后 ,就 可 以 在 客户 端 通过 浏览 器 
来 访问 JSP 页 面 了 。 

如 图 1-1 所 示 是 JSP 技术 生成 动态 页 面 内 容 的 过 程 。 

一 个 JSP 页 面 的 执行 过 程 可 以 分 为 以 下 几 个 步骤 。 

COD 浏览 器 客户 端 向 JSP 引擎 发 出 对 ISP 页 面 的 请 求 。 

(2) JSP 引擎 将 对 应 的 JSP 页 面 转换 成 Java Servlet 源 代码 。 

(3) JSP 引擎 编译 生成 源 代码 ,生成 . class 文件 。 

(4) JSP 引擎 加 载运 行 对 应 的 . class 文件 ,生成 响应 的 结果 页 面 (JVM 是 java 虚拟 
机 ,将 java 的 class 字 节 码 文件 翻译 成 二 进 制 可 执行 程序 ) 。 

(5) JSP 引擎 把 响应 的 输出 结果 发 送 到 客户 端 浏 览 器 。 


! 
服务 器 

一 一 1 
" JSP 页 面 


创建 /修改 后 
第 一 次 调用 


Servlet(.java) 
JSP5|% 1 
Class 文 件 (.class) 


JSP 编 译 器 Y 
JVM = 


JSP 页 面 


i 


图 1-1 JSP 工作 流程 


JSP 引擎 管理 JSP 页 面 生命 周期 的 两 个 阶段 : 转换 阶段 和 执行 阶段 。 当 有 一 个 对 
JSP 页 面 的 请 求 到 来 时 ,JSP 引擎 检验 ISP 页 面 的 语法 是 否 正确 ,将 ISP 页 面 转换 为 
Servlet 源 文 件 , 然 后 调用 Javac 工具 类 编译 Servlet 源 文件 生成 字 节 码 文 件 , 这 一 阶段 是 
转换 阶段 。 接 下 来 ,Servlet 引擎 加 载 转换 后 的 Servlet 类 .实例 化 一 个 对 象 处 理 客户 端的 
请 求 , 在 请 求 处 理 完成 后 ,响应 对 象 被 JSP 引擎 吸收 ,引擎 将 HTML 格式 的 响应 信息 发 
送 到 客户 端 ,这 一 阶段 是 执行 阶段 。 

从 整个 过 程 中 可 以 知道 , 当 第 一 次 加 载 JSP 页 面 时 ,因为 要 将 JSP 页 面 转换 为 
Servlet 源 文件 ,所 以 响应 速度 较 慢 。 当 再 次 请 求 时 ,JSP 引擎 就 会 直接 执行 第 一 次 请 求 


时 产生 的 Servlet. 而 不 会 再 重新 转换 JSP 页 面 ,所 以 其 执行 速度 和 原始 的 Servlet 执行 速 
度 几 乎 就 一 样 了 。 在 ISP 执行 期 间 ,JSP 引擎 会 查看 JSP 页 面 ,看 是 否 有 更 新 或 修改 。 如 
果 有 更 新 或 修改 ,JSP 引擎 会 再 次 编译 JSP 或 Servlet; 如 果 没 有 更 新 或 修改 ,就 直接 执行 
前 面 产 生 的 Servlet. 


1.1.3 JSP, JaveBean 和 Java Servlet 的 关系 


Java Servlet 是 Java 语言 的 一 部 分 , 它 提 供 了 一 组 用 于 服务 器 端 编程 的 API。 习 惯 
上 称 使 用 Java Servlet API 的 相关 类 和 方法 所 编写 的 Java 类 为 Servlet 类 ,Servlet KA 
成 的 对 象 为 Servlet WH, Servlet 对 象 可 以 在 配置 有 ISP 运行 环境 的 服务 器 上 运行 , 访 
问 服务 器 的 各 种 资源 ,这 极 大 地 扩展 了 服务 器 的 功能 。 

JSP 是 晚 于 Java Servlet 产生 的 以 Java Servlet 技术 为 基础 的 Web 应 用 开发 技术 标 
HE. JSP 保留 了 Java Servlet 几乎 所 有 的 优点 ,是 Java Servlet 技术 的 成 功 应 用 ,但 JSP 只 
是 Java Servlet 技术 的 一 部 分 ,而 不 是 Java Servlet 的 全 部 。JSP 可 以 让 JSP 标记 、Java 
语言 代码 嵌入 HTML 语句 中 ,大 大 地 简化 和 方便 了 网 页 的 设计 和 修改 ,但 JSP 页 面 最 终 
会 被 编译 成 Servlet 并 执行 ,来 响应 客户 端的 请 求 。 

JavaBean 被 Sun 公司 定义 为 一 个 可 重用 的 软件 组 件 。 实 际 上 ,JavaBean 就 是 一 种 
Java 类 ,通过 封装 属性 和 方法 成 为 具 行 某 种 业务 逻辑 处 理 能 力 的 类 , 它 一 般 负 责 Web 应 
用 系统 的 业务 逻辑 处 理 部 分 。JavaBean 类 实例 化 的 对 象 简称 为 Bean, JSP 提供 访问 
JavaBean 组 件 的 JSP 动作 标记 。JSP 动作 标记 简单 .方便 ,有 效 地 分 离 了 JSP 页 面 的 表 
示 部 分 和 业务 逻辑 ,数据 处 理 部 分 ,因此 使 程序 设计 人 员 和 页 面 设计 人 员 可 以 同时 工作 。 

较 小 规模 的 Web 应 用 可 以 采用 JSP 十 JavaBean 模式 。 在 JSP 十 JavaBean 模式 中 ， 
JSP 负责 页 面 的 显示 、 页 面 预 处 理 和 跳 转 控制 ,JavaBean 负责 业务 逻辑 和 数据 处 理 。 对 于 
规模 较 大 的 Web 应 用 ,就 需要 采用 JSP + JavaBean + JavaServlet 模式 。 在 JSP 十 
JavaBean+ JavaServlet 模式 中 ,JSP 负责 页 面 显 示 (View) ,JavaBean 负责 业务 逻辑 和 数 
据 处 理 (Model) ,JavaServlet 负责 处 理 和 分 发 页 面 的 请 求 (Controler) 。 


1.1.4 JP, ASP, ASP.NET, PHP AY EE E 


JSP 是 一 种 动态 网 页 技术 标准 ,主要 是 Java 语言 在 Web 方面 的 运用 。JSP 的 优势 是 
跨 平 台 , 既 能 在 Linux 下 运行 ,也 能 在 其 他 操作 系统 上 运行 。 经 过 这 些 年 的 发 展 ,JSP 技 
术 在 市 场 上 的 应 用 越 来 越 广泛 ,而 且 一 般 为 大 中 型 项 目 , 这 就 带 来 了 更 多 的 就 业 机 会 。 由 
于 Java 发 展 经 久 不 训 , 所 以 JSP 技术 的 应 用 也 有 了 更 广阔 的 空间 。 对 于 学 习 Java 的 同 
学 们 ,JSP 也 是 必 学 的 技术 之 一 ,许多 培训 机 构 也 会 将 JSP 作为 Java 的 基础 课程 讲授 。 

对 于 做 网 站 ,也 就 是 Web 类 服务 ,曾经 特别 流行 三 大 体系 , 即 JSP.ASP fil PHP, 后 
来 经 过 微软 对 ASP 的 升级 换代 ,目前 ASP 基本 淡出 舞台 了 ,取而代之 的 是 ASP. NET. 
ASP 可 以 说 是 ASP. NET 的 前 身 。 实 际 上 ,JSP、ASP 和 PHP 都 只 是 一 种 技术 ,本 身 不 

那么 ,JSP、ASP 和 PHP, 到 底 有 什么 区 别 ,学 习 哪 个 更 有 前 途 ? 今天 就 为 大 家 分 析 
=P. 
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目前 ,PHP 与 ASP 在 国内 应 用 最 为 广泛 ,而 JSP 采用 的 较 少 。 但 在 国外 ,JSP 已 经 
是 比较 流行 的 一 种 技术 ,尤其 是 电子 商务 类 的 网 站 多 采用 JSP. 

采用 PHP 的 网 站 如 新 浪 网 (sina) 、 中 国人 (Chinaren) 等 ,但 PHP 不 适合 应 用 于 大 型 
的 电子 商务 网 站 ,而 更 适合 一 些小 型 的 商业 网 站 ,因为 PHP 缺乏 规模 支持 和 多 层 结构 支 
持 。 对 于 大 负荷 站 点 ,解决 方法 只 有 一 个 : 分 布 计算 。 数 据 库 .应 用 逻辑 层 . 表 示 逻 辑 层 
彼此 分 开 ,而 且 同 层 也 可 以 根据 流量 分 开 , 组 成 二 维 阵列 ,而 PHP 则 缺乏 这 种 支持 。JSP 
可 以 利用 JDBC 和 众多 主流 关系 数据 库 连 接 ,PHP 目前 只 支持 MySql 和 Oracle 等 有 限 
的 几 种 ,此 外 PHP 提供 的 数据 库 接口 支持 不 统一 ,这 也 使 得 它 不 适合 运用 在 电子 商 
务 中 。 

ASP 是 Active Server Pages 的 缩写 ,是 微软 在 早期 推出 的 动态 网 页 制作 技术 ,包含 
在 IIS(Internet 信息 服务 ) 中 ,是 一 种 服务 器 端的 脚本 编写 环境 ,可 以 用 于 创建 和 运行 动 
态 、 交 互 的 Web 服务 器 应 用 程序 。 在 动态 网 页 技术 发 展 的 早期 ,ASP 是 绝对 的 主流 技 
术 , 但 是 它 也 存在 着 许多 缺陷 : 由 于 ASP 的 核心 是 脚本 语言 ,所 以 需要 通过 解释 执行 代 
码 , 因 此 运行 效率 较 低 ; 同时 由 于 脚本 代码 与 HTML 代码 混在 一 起 ,因此 不 便于 开发 人 
员 进 行 管理 与 维护 。 随 着 技术 的 发 展 ,ASP 的 辉煌 已 经 成 为 过 去 ,微软 也 已 经 不 再 对 
ASP 提供 技术 支持 和 更 新 ,ASP 技术 目前 处 于 被 淘汰 的 边缘 。 

ASP. NET 是 微软 继 ASP 后 推出 的 全 新 的 动态 网 页 制作 技术 。 在 性 能 上 ， 
ASP. NET It ASP 强 得 多 ,与 PHP 相 比 ,也 存在 显著 优势 。ASP. NET 可 以 使 用 CH, 
VB. NET, Visual J # 等 语言 来 开发 。ASP. NET 依托 . NET 平台 先进 而 强大 的 功能 , 极 
大 地 简化 了 编程 人 员 的 工作 ,使 得 Web 应 用 程序 的 开发 更 加 方便 ,快捷 ,同时 也 使 得 程序 
的 功能 更 加 强大 ,是 JSP 技术 的 有 力 竞争 对 手 。 然 后 在 ASP. NET 代替 ASP 之 后 的 这 些 
年 ,C# 还 不 足以 与 Java 竞争 。 对 于 从 业 人 员 的 待遇 更 是 不 如 Java。 所 以 ,ASP. NET 的 
WIE. 


1.2 搭建 JSP 运行 环境 


使 用 JSP 开发 Web 应 用 程序 时 ,必须 搭建 一 个 JSP 运行 环境 。JSP 运行 环境 至 少 需 
要 具备 三 个 基本 条 件 : 要 在 用 户 的 计算 机 上 安装 Java 的 JDK(Java Development Kit) ,并 
进行 环境 变量 的 设置 ; 要 在 计算 机 上 安装 ISP 引擎 ,例如 Tomcat; 要 在 计算 机 上 有 浏 
览 器 。 
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JDK 是 Sun 公司 针对 Java 开发 员 所 设计 的 产品 。JDK 是 整个 Java 的 核心 ,包括 了 
Java 运行 环境 .Java 工具 和 Java 基础 的 类 库 。 

JSK 的 版 本 分 类 如 下 。 

(1) SE(J2SE) ,standard edition ,标准 版 ,是 通常 使 用 的 一 个 版 本 ,从 JDK 5. 0 开始 ， 
改名 为 Java SE。 

(2) EE(J2EE) ,enterprise edition ,企业 版 .使 用 这 种 JDK 可 开发 J]2EE 应 用 程序 ,从 
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JDK 5. 0 开始 ,改名 为 Java EE. 
(3) ME(J2ME) , micro edtion ,主要 用 于 移动 设备 . 嵌 人 式 设备 上 的 Java 应 用 程序 开 
发 ,从 JDK 5.0 开始 ,改名 为 Java ME。 


1. JDK 的 下 载 


CD 首先 ,我 们 可 以 在 Sun 公司 的 官方 网 站 http://java. sun. com 下 载 JDK 的 最 新 
版 本 。 进 入 官网 后 我 们 会 看 到 以 下 界面 ,选择 Downloads 菜单 一 一 Java SE, 如 图 1-2 
所 示 。 


(È | 4: Developer Resources for Java T... | 


ORACLE’ sun Developer Network (SDN) 


APis Downloads Products Support Training Participate 


Feature 。 


图 1-2 Sun 公司 的 官方 网 站 
(2) 进入 Java SE 页 面 , 单 击 JDK 6 Update 19 右 侧 的 Download JDK 按钮 ,如 图 1-3 
所 示 o 


k |$ Java SE Downloads - Sun Develo... | | 8-8 @- 


Overview Technologies Documentation Community Support IET 


Latest Release | Next Release (Early Access) | Embe Real-Time | Previous Releases 


Java Platform (JDK) JDK + JavaFX Bundle JDK + NetBeans Bundle JDK + Java EE Bundle 
» JOK » JRE 


Here are the Java SE downloads In detail. 


JDK 6 Update 19 (JDK or JRE) 


This release contains critical security updates to the Java runtime. Please 
update now to take advantage of these enhancements. " Leam more Doss = 


[Download Java £ 
Update 19 
What Java Do Need? You must have a copy ofthe JRE (Java Runtime 


图 1-3 Java SE 页 面 


(3) 进入 下 载 页 面 ,选择 操作 平台 Windows, 勾 选 上 复 选 框 表示 同意 协议 , 单 击 
Download 按钮 ,如 图 1-4 所 示 。 

(4) 弹出 登录 的 窗口 如 图 1-5 所 示 , 可 以 单 击 Skip this Step 跳 过 这 个 步骤 , 即 可 进入 
最 后 一 步 。 
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Download the complete platform 
Use your creative talents to design a winning applicat. 


JDK 6 Update 19 


This special release provi 


» FAQ 

» Installation Instructions 
» ReadMe 

» ReleaseNotes 

» Sun License 

» Third Party Licenses 

» Supported System Cor 


By selecting Download or Continue’ below, you 
hereby accept the terms and conditions of the Java 
SE Development Kit u19 License Agreement. 


Log in with your Sun Online Account or Create a New Account to 
receive member benefits including access to 


* Your download transaction history online 


* Alerts and updates for downloaded software 
* Future offers including white papers and training discounts 


User Name 


Password | 


Log in and Continue 


图 1-5 JDK 下 载 登录 页 面 


(5) 直接 进入 下 载 页 面 如 图 1-6 所 示 , 单 击 jdk-6u19-windows-i586. exe 下 载 文件 。 


Download Java SE Development Kit 6u19 for Windows, Mull 


language 


Download Information and Files 


There is more information on the available files for download on the Supported 


System Configurations page. 


Instructions: Select the files you want, then click the "Download Selected with Sun Download 
Manager (SDM) button below to automatically install and use SDM (leam more). Alternately, click 
directly on file names to download with your browser. (Use of SDM is recommended but not 
required.) 


1 SDM, 


click the file link below t 


Troubleshooting | 
Ei File Description and Name E 


76.87 MB 


图 1-6 JDK 程序 下 载 页 面 
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2. 安装 


CD 双击 刚 下 载 好 的 jdk-6u19-windows-i586. exe. 3 tH. JDK 欢迎 界面 如 图 1-7(a) 所 
示 和 协议 界面 如 图 1-7(b) 所 示 。 


i? Java(TM) SE Development Kit 6 Update 19 KOR) 


@ Sun 


欢迎 使 用 Java(TM) SE Development Kit 6 Update 19 安装 向 导 


aam SE Development Kit 6 iced 19 安 奖 程序 正在 准备 安装 向 导 ， 安 装 向 导 将 引 
您 完成 程序 安装 过 程 。 请 稍 候 


(a) JDK 安 装 欢迎 界面 
€ Java(TM) SE Development Kit 6 Update 19 - if... X] 


的 许可 证 协议 。 Sun 


[Sun Microsystems, Inc. Binary Code License Agreement 


for the JAVA SE DEVELOPMENT KIT (JDK), VERSION 6 


SUN MICROSYSTEMS, INC. SUN") IS WILLING TO LICENSE THE SOFTWARE IDENTIFIED 
IBELOW TO YOU ONLY UPON THE CONDITION THAT YOU ACCEPT ALL OF THE TERMS 
CONTAINED IN THIS BINARY CODE LICENSE AGREEMENT AND SUPPLEMENTAL LICENSE 
|TERMS (COLLECTIVELY "AGREEMENT". PLEASE READ THE AGREEMENT CAREFULLY 

BY USING THE SOFTWARE YOU ACKNOWLEDGE THAT YOU HAVE READ THE TERMS AND 
[AGREE TO THEM. IF YOU ARE AGREEING TO THESE TERMS ON BEHALF OF A COMPANY 

OR OTHER LEGAL ENTITY, YOU REPRESENT THAT YOU HAVE THE LEGAL AUTHORITY TO 
BIND THE LEGAL ENTITY TO THESE TERMS. IF YOU DO NOT HAVE SUCH AUTHORITY, OR 

IF YOU DO NOT WISH TO BE BOUND BY THE TERMS, THEN YOU MUST NOT USE THE ~ 


(b)JDK 协 议 界面 
图 1-7 


(2) 单 击 “ 接 受 ” 按 钮 将 出 现 如 图 1-8 所 示 窗 口 , 单 击 “ 更 改 ” 按 钮 ,修改 安装 路 径 如 
图 1-9 所 示 , 单 击 “ 确 定 ” 按 钮 ,确定 已 修改 的 路 径 ,然后 单 击 * 下 一 步 " 按 钮 ,完成 JDK 的 
安装 。 

(3) 安装 过 程 中 弹出 JRE 的 安装 窗口 ,如 图 1-10 所 示 , 单 击 “ 更 改 ” 按 钮 把 路 径 修改 
为 d:\Program Files\Java\jre6\, 如 图 1-11 所 示 . 单 击 “ 确 定 ” 按 钮 ,继续 安装 。 

(A) 安装 完成 弹出 窗口 ,如 图 1-12 所 示 。 


SW Java(TM) SE Development Kit 6 Update 19 - B... [K] 


È Sun 


P E alee SES. SUARA EHDE PA FANE 


功能 说 明 

Java(TM) SE Development kit 6 
Update 19， 包括 专 用 RES 
Update 19。 这 将 需要 300 MB 
BRR. 


C:\Program Fles\Java\k 1.6.0_19\ 


<t-¥®) 下 一 步 QD > 


图 1-8 JDK 自 定义 安装 界面 


9 Java(TM) SE Development Kit 6 Update 19 


wena 


@Sun 


人 未 150_19 


KERERE: 
[Program Fles\Java\jdk1.6.0_19\] 


图 1-9 JDK 安装 路 径 选 择 界面 


@Java 安装 - 目标 文件 夹 区 


[i Brite 


"——Á" È Sur 


安装 到 : 
C:\Program Fies\Java\ye6\ 


1-10 JRE 安装 窗口 


mexik 
WIE PORC PES. 


AERO: 
[Program Fles\ava\res\ 


19 Java(TM) SE Development Kit 6 Update 19 - 完成 X) 


@ Sun 


Java(TM) SE Development Kit 6 Update 19 已 成 功 安装 
产品 注册 是 免费 的 ， 您 将 获得 如 下 增值 服务 ， 

获得 新 版 本 、 修 补 程序 和 更 新 的 通知 服务 

* 获得 有 关 Sun 开发 者 产品 、 服 务 和 培训 的 优惠 

* 获得 对 早期 版 本 和 文档 的 访问 权限 


当 您 单 击 " 完 成 "后 将 收集 产品 与 系统 信息 ， 同 时 显示 JOK 产品 注册 表单 ， 如 果 您 不 注 
册 ， 则 不 保存 以 上 信息 。 


a ee 请 参见 "产品 注册 


FRE 


Æ 1-12 JDK 安装 完成 窗口 


3. X T JDK f£ JRE 


刚才 在 安装 JDK 的 时 候 让 我 们 选择 是 否 安装 单独 的 JRE, 一 般 都 会 一 起 安装 ,因为 
这 样 更 能 帮助 大 家 弄 清 楚 它们 的 区 别 。 

现在 我 们 来 看 一 下 安装 好 的 java 目录 ,在 目录 下 有 一 个 jdk 目录 和 一 个 jre 目录 。 

JDK 是 Java 的 开发 工具 包 , 里 面包 含 了 各 种 类 库 和 工具 。jdk 目录 下 面 有 6 个 文件 
夹 一 个 src 类 库 源 码 压 缩 包 和 其 他 几 个 声明 文件 。 其 中 .真正 在 运行 java 时 起 作用 的 是 
以 下 四 个 文件 夹 : bin、include.lib、jre。 

bin: 编译 器 (javac. exe); 

include: Java 和 JVM 交互 用 的 头 文件 ; 


lib: 所 有 Java 类 库 的 class 文件 ,都 在 lib 目录 下 打包 成 了 jar; 

jre: java runtime environment, 是 Java 程序 的 运行 环境 。 既 然 是 运行 ,当然 要 包含 
jvm, 也 就 是 虚拟 机 ,JDK 的 jre/bin/client 和 server 两 个 文件 夹 下 都 包含 一 个 jvm. dll, 说 
明 是 有 两 个 虚拟 机 的 。 

jdk 目录 下 的 bin 文件 夹 中 有 各 种 Java 程序 需要 用 到 的 命令 ,与 jre 目录 下 的 bin X 
件 夹 最 明显 的 区 别 在 于 jdk FAA javac, 具 备 开发 功能 的 jdk 自己 的 jre 下 才 会 同时 有 
client 性 质 的 jvm 和 server 性 质 的 jvm, 而 仅仅 作为 运行 环境 的 jre 下 只 需要 client 性 质 
AY jvm. dll 就 够 了 (jdk 目录 外 的 jre 只 是 java 的 运行 环境 ) 。 

简单 地 说 ,JDK 是 面向 开发 人 员 使 用 的 , 它 提供 了 Java 的 开发 环境 和 运行 环境 ,可 以 
包括 函数 库 ,编译 程序 等 。JRE 是 Java 的 运行 环境 ,是 面向 Java 程序 的 使 用 者 ,而 不 是 
开发 者 。jdk 目录 里 的 工具 是 用 Java 编写 的 ,所 以 也 是 Java 的 应 用 程序 ,因此 也 必须 要 
自行 附 一 套 jre 才 行 。 


122 JIK 环 境 变量 设置 


(1) 布 击 “我 的 电脑 ”一 “属性 ”, 在 弹出 窗口 上 点 击 “ 高 级 ”选项 卡 , 如 图 1-13 所 示 。 
(2) 单 击 “环境 变量 ”按钮 ,弹出 窗口 如 图 1-14 Bros ,新 建 系统 变量 : 
path=D;\Program Files\Java\jdk1. 6.0_19\bin ,如 图 1-15 所 示 ; 
classpath —. ;D:\Program Files\Java\jdk1. 6. 0_19\jre\lib, 如 图 1-16 所 示 。 

系统 属性 


[xn | its |e (AUC 系统 还 原 | 自动 更 新 | 远程 
要 进行 大 多 数 改 动 ， 您 必须 作为 管理 员 警 录 。 a 


性 能 C:\Docunents and Settings \Adni 
" C:\Documents and Settings Mdni 
视觉 效果 ,处理 器 计划 ， 内 存 使 用 ， 以 及 虚拟 内 存 


Administrator 的 用 户 变 量 V 


uus Cam] 


与 您 登录 有 关 的 点 面 设置 


启动 和 故障 恢复 
系统 启动 ， 系 统 失 败 和 调试 信息 


Windows NT 


J 
mmo 


新 建 系统 变量 E33 新 建 系统 变量 


RSW [path classpath 


RRAV [D:\Program Files\Java\jdkl.6.0_19\b: :D:\Progran Files\Java\jdkl. 6.0_19" 


[确定 取消 确定 取消 


图 1-15 新 建 系统 变量 窗口 (path) 图 1-16 新 建 系统 变量 窗口 (classpath) 


O [动态 网 站 设计 S 制 f 一 J5sP] ooo 


G) 打开 “开始 ”一 “运行 ”, 在 弹出 窗口 输入 cmd, 
(4) 在 窗口 中 输入 代码 如 下 : 


d: //d: 表 示 打 开 DD 盘 

javac //javac 是 java 程序 的 编译 器 

单 击 Enter 键 后 显示 结果 如 图 1-17 所 示 , 列 出 了 JDK 中 javac 的 用 法 ,这 就 表示 测试 
环境 成 功 了 。 


图 1-17 JDK 环境 测试 结果 窗口 


123 Tomcat 的 下 载 与 安装 


Tomcat 是 Apache 软件 基金 会 (Apache Software Foundation) 的 Jakarta 项 目 中 的 
-个 核心 项 目 , 由 Apache, Sun 和 其 他 一 些 公司 及 个 人 共同 开发 而 成 。 由 于 有 了 Sun 的 
参与 和 支持 ,最 新 的 Servlet 和 JSP 规范 总 是 能 在 Tomcat 中 得 到 体现 ,Tomcat 5 支持 最 
新 的 Servlet 2.4 和 JSP 2. 0 规范 。 因 为 Tomcat 技术 先进 ,性 能 稳定 ,而 且 免 费 ,因而 深 
A Java 爱好 者 的 喜爱 ,并 得 到 了 部 分 软件 开发 商 的 认可 ,成 为 目前 比较 流行 的 Web 应 用 
服务 器 。 目 前 最 新 版 本 是 6. 0。 
Tomcat 是 一 个 小 型 的 轻 量 级 应 用 服务 器 ,是 开发 和 调试 JSP 程序 的 首选 。 对 于 初 
学 者 来 说 ,可 以 认为 , 当 在 一 台 机 器 上 配置 好 Apache 服务 器 ,可 利用 它 响应 对 HTML 页 
面 的 访问 请 求 。Tomcat 和 UIS. Apache 等 Web 服务 器 一 样 , 具 有 处 理 HTML 页 面 的 功 
能 ,另外 它 还 是 一 个 Servlet 和 JSP 容器 ,独立 的 Servlet 容器 是 Tomcat 的 默认 模式 。 实 
际 上 ,Tomcat 部 分 是 Apache 服务 器 的 扩展 ,但 它 是 独立 运行 的 ,所 以 当 运 行 Tomcat 时 ， 
实际 上 是 作为 一 个 与 Apache 独立 的 进程 单独 运行 的 。 


1. 下 载 Tomcat 


(1) 可 以 从 http://tomcat. apache. org/ 网 站 下 载 ,进入 官网 后 我 们 会 看 到 以 下 界面 ， 
如 图 1-18 所 示 。 

(2) 单 击 Tomcat 6. x 链接 ,进入 下 载 页 面 , 单 击 Windows Service Installer, 就 可 以 
下 载 Tomcat 6.0 了 ,如 图 1-19 Pras. 


2. 安装 Tomcat 


这 里 使 用 的 Tomcat 是 6. 0 版 本 ,平台 为 Windows, 安 装 之 前 必须 完成 上 述 的 JDK 
的 安装 。 
CD 双击 已 下 载 好 的 apache-tomcat-6. 0. 26. exe 文件 ,将 出 现 如 图 1-20 所 示 的 界面 


© Apache fe ! - Windows Internet Explorer 


GO- Notto://tomat. apache. ors/ 
Xf) MAO HEV 收藏 大 IAD Head 
te © [N Apache Tomcet - Welcome! 


Apache Tomcat D. Apache 


Software Foundation 


http://www.apache.org/ 
TEN YEARS OF TOMCAT 


Seuck the Site 


Apache Tomcat Apache Tomcat 


is developed in an open and partic 
released under the Apache Toncat is intended to 
be a opers from around the world. 
We invite you to p pate in this open development project. To learn 


Documentation 


Please see the README file for packaging information. It explains what 
every distribution contains. 


Binary Distributions 


E Apache Tomcat Setup 


Welcome to the Apache Tomcat 
Setup Wizard 


This wizard wil guide you through the installation of Apache 
Tomcat. 


tis recommended that you close all other appications 
before starting Setup. This wil make & possble to update 
relevant system fies without having to reboot your 
computer 


ick Next to continue, 


Apache Tomcat 6 
tomeat.apache.org 


3» http:/ 


1-20 Tomcat 安装 界面 


O (asmetan) 00000 


(2) Mit Next 按钮 ,选择 下 拉 菜 单 中 的 Full, 如 图 1-21 所 示 。 


BApache Tomcat Setup "m 


Choose Components. 
Choose which features of Apache Tomcat you want to install 


Check the components you want to install and uncheck the components you don't want to 


install, Chk Next to continue 
Soe he yoe ot ret aS 
Or, select the optional E [V] Tomcat. ue) 
components you wsh to Bic Meo bea 
* [v] Documentation. 
[v] Manager 
[v] Host Manager. 
E] Examples 


‘Space required: 13.1MB. 


图 1-21 Tomcat 安装 选择 界面 
(3) 单 击 Browse 修改 安装 路 径 如 图 1-22 所 示 , 单 击 Next 开始 安装 ,在 安装 过 程 中 


会 弹出 如 图 1-23 所 示 的 界面 ,如 果 JDK 安装 正确 ,Tomcat 会 自动 识别 jre 的 路 径 , 单 击 
Install 按钮 ,完成 安装 。 


Choose Install Location 
Choose the folder in which to install Apache Tomcat a 
dust pe ta KH Nl fo aei b adiri dic 


Browse and select another folder. Chek Next to 


Destination Folder 


di\Program Files\Apache Software Foundation\Tomcat 6.0 Browse... 


Space requred: 13.1MB 
Space avallable: 7.468 


图 1-22 Tomcat 安装 路 径 设置 界面 


BApache Tomcat Setup: Java Vi... [c | 


Java Virtual Machine 
Java Vetual Machine path selection. 


Please select the path of 3 J2SE 5.0 or later JRE installed on your system. Note that if you 
have a 64-bt operating system, you must specify a 64-bt JRE: 


Cea JL eat Cm ] 
图 1-23 Tomcat 安装 中 jre 的 路 径 选 择 界面 


Completing the Apache Tomcat 
Setup Wizard 


Apache Tomcat has been installed on your computer. 
‘Click Finish to dose this wizard. 
[Run Apache Tomcat] 


[l Show Readme 
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图 1-24 Tomcat 安装 完成 界面 


3. Tomcat 的 目录 结构 


/bin: 存放 windows 或 Linux 平 台 上 启动 和 关闭 Tomcat 的 脚本 文件 。 

/conf; 存放 Tomcat 服务 器 的 各 种 全 局 配置 文件 ,其 中 最 重要 的 是 server. xml 和 
web. xml, 

/doc: 存放 Tomcat 文档 。 

/server: 包含 classes \lib 和 webapps 三 个 子 目录 。 

/server/lib: 存放 Tomcat 服务 器 所 需 的 各 种 JAR 文件 。 

/server/webapps: 存放 Tomcat 自 带 的 两 个 Web 应 用 admin 应 用 和 manager 
应 用 。 

/common/lib: 存放 Tomcat 服务 器 以 及 所 有 Web 应 用 都 可 以 访问 的 jar 文件 。 

/shared/lib: 存放 所 有 Web 应 用 都 可 以 访问 的 jar 文件 (但 是 不 能 被 Tomcat 服务 器 
访问 ) 。 

/logs: 存放 Tomcat 执行 时 的 日 志文 件 。 

/src: 存放 Tomcat 的 源 代码 。 

/webapps: Tomcat 的 主要 Web 发 布 目录 ,默认 情况 下 把 Web 应 用 文件 放 于 此 
目录 。 
/work: 存放 JSP 编译 后 产生 的 class 文件 。 


124 测试 Tamcat 
1. 测试 Tomcat 


Tomcat 启动 后 ,在 任务 栏 有 力图 标 . 这 是 Apache Tomcat 启动 的 标志 。 在 浏览 器 的 
地 址 栏 输入 http://127. 0. 0. 1:8080 或 http://localhost: 8080, 会 出 现 如 图 1-25 所 示 的 


欢迎 界面 ,表示 启动 成 功 。 


ache Tomcat - Windows Internet Explorer 
ow E) http://127. 0. 0. 1:8080/ 
XO 编辑) HEV Rew IRO 300 
Xt €t |e) Apache Tomcat n-A #- OREO OTA ~ ” 


Apache Tomcat 
i The Apache Software Foundation 


http://www.apache.org/ 


It you're seeing this page via a web browser, it means you've setup Tomcat 
successfully. Congratulations! 


As you may have guessed by now, this is the default Tomcat home page. It can be found on 
the jem at 


SCATALINA_HOME/webapps/ROOT/ index.html 


where “SCATALINA_HOME" is the root of the Tomcat installation directory. If you're seeing 
this page, and you don't think you should be, then you're either a user who has arrived at new 
installation of Tomcat, or you're an administrator who hasn't got his/her setup quite right. 
Providing the latter is the case, please refer to the Tomcat Documentation for more detailed 
setup and administration information than is found in the INSTALL file. 


NOTE: For security reasons, using the manager webapp is restricted to users with 
role "manager". Users are defined in 1cATALINA H0NE/cont/toncet-ueecs. xal. 


Included with this release are a host of sample Serviets and JSPs (with associated source 
code), extensive documentation, and an introductory guide to developing web applications. 


图 1-25 Apache Tomcat 欢迎 界面 


注意 : 127.0.0.1 是 回 送 地 址 , 指 本 地 机 ,一 般 用 来 测试 使 用 。 在 有 类 IP 地 址 的 规定 
中 ,第 一 部 分 是 1 一 126 AA 类 地 址 ,128 一 191 为 已 类 地 址 ,那么 中 间 留 的 127. 0. 0. 1 被 
称 为 本 地 回环 地 址 ,主要 作用 有 两 个 : 一 个 是 测试 本 机 的 网 络 配置 ,能 PING 通 127.0.0.1 
说 明 本 机 的 网 卡 和 IP 协议 安装 都 没有 问题 ; 另 一 个 是 某 些 SERVERVCLIENT 的 应 用 程 
序 在 运行 时 需 调 用 服务 器 上 的 资源 ,一 般 要 指定 SERVER 的 IP 地 址 ,但 当 该 程序 要 在 同 
一 台 机 器 上 运行 而 没有 别 的 SERVER 时 就 可 以 把 SERVER 的 资源 装 在 本 机 ,SERVER 
的 IP 地 址 设 为 127.0.0.1 也 同样 可 以 运行 。 对 于 大 多 数 习惯 用 localhost 的 用 户 来 说 ， 
实质 上 就 是 指向 127.0.0. 1 这 个 本 地 IP 地 址 ,在 操作 系统 中 有 个 配置 文件 将 localhost 
5 127.0.0.1 绑 定 在 了 一 起 。 


2. 增加 虚拟 服务 端口 号 


如 果 安 装 好 的 Tomcat 在 端口 上 与 其 他 开发 工具 有 冲突 ,或 者 想 重 新 找 一 个 端口 号 ， 
那么 可 以 通过 增加 虚拟 服务 端口 号 的 方法 来 解决 。 首 先 打 开 D:\Program Files\Apache 
Software Foundation\ Tomcat 6. 0\conf 路 径 下 的 server. xml, 可 以 使 用 任何 一 种 文本 编 
辑 器 打开 ,找到 下 面 这 段 语句 : 

<Connector port— "8080" protocol="HTTP/1. 1"connectionTimeout= "20000" redirectPort— "8443" /> 

然后 把 这 一 段 复 制 并 粘贴 在 原 语句 的 后 面 ,把 复制 的 这 段 语 句 中 8080 BEA 2010 或 


其 他 不 冲突 的 端口 号 ,最 后 保存 并 关闭 server. xml 文件 ,重启 Tomcat。 在 浏览 器 的 地 址 
栏 输 入 http://127. 0.0.1:2010, 如 果 出 现 如 图 1-25 所 示 的 页 面 , 即 为 修改 成 功 。 


1.8 JSP 开发 工具 MyEclipse 


MyEclipse 企业 级 工作 平台 (MyEclipse Enterprise Workbench , MyEclipse) 是 对 
Eclipse IDE 的 扩展 ,利用 它 用 户 可 以 在 数据 库 和 Java EE 的 开发 ,发 布 ,以 及 应 用 程序 服 
务 器 的 整合 方面 极 大 地 提高 工作 效率 。MyEclipse 是 功能 丰富 的 Java EE 集成 开发 环 
境 ,包括 了 完备 的 编码 .调试 .测试 和 发 布 功能 ,完整 支持 HTML, Struts, JSF, CSS, 
Javascript. SQL. Hibernate, 

在 结构 上 ,MyEclipse 的 特征 可 以 被 分 为 以 下 7 类 : 

(1) Java EE 模型 ; 

(2) Web 开发 工具 ; 

G) EJB 开发 工具 ; 

(4) 应 用 程序 服务 器 的 连接 器 ; 

(5) Java EE 项 目 部 署 服务 ; 

(6) 数据 库 服 务 ; 

(7) MyEclipse 整合 帮助 。 

简单 而 言 , MyEclipse 是 Eclipse 的 插件 ,也 是 一 款 功能 强大 的 Java EE 集成 开发 环 
境 ,支持 代码 编写 配置、 测试 以 及 除 错 , MyEclipse 6. 0 以 前 版 本 需 先 安装 Eclipse. 
MyEclipse 6. 0 以 后 版 本 安装 时 不 需 安装 Eclipse. 


1.31 MEclipse 的 下 载 与 安装 


(D 下 载 MyEclipse 版 本 配合 JDK 1.6 和 Tomcat 6.0 使 用 。 
(2) 双击 运行 下 载 的 文件 MyEclipse 6.0. 1GA_E3. 3. 1. Installer. exe, 如 图 1-26 所 
IR ,准备 工作 好 了 以 后 ,出 现 如 图 1-27 所 示 的 安装 提示 界面 。 


InstallAnywhere 


w InstalAnywhere 正在 做 安装 准备 


[TD 
80% 


(C) 2002-2006 Macrovision Europe Ltd. and/or Macrovision Corporation 


1-26 MyEclipse 安装 准备 界面 
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MyEclipse 6.0.1 33m]. 4 
Introduction 
© Introductior This installer will quide you through the installation of MyEclipse 6.0.1 
Ucense. ni httpJwwwr myeclipseide.com) which is an IDE that facilitates J2EE f 
» Web / AJAX development. You do not need to download or install any 
additional pieces of software to run MyEclipse. All prerequisites will be 
installed for you. 


Please use the "Nexf and "Previous" buttons during the installation to 
continue through or step back through the installation process. 


Release Notes? Pressing "Cancer at any time will stop the installation. 
Install Complete. 


Cancel 


1-27 MyEclipse 安装 界面 


(3) 先 单 击 Next ,接受 协议 ,再 单 击 Next, 如 图 1-28 所 示 ,修改 好 MyEclipse 的 目录 
之 后 ,再 单 击 Next, 选择 MyEclipse 的 安装 目录 之 后 ,继续 单 击 Next. 直到 最 后 完成 
MyEclipse 的 安装 。 


v MyEclipse I, Ec X) 


Choose Install Folder 


MyEclipse 6.0.1 can be installed anywhere on your file system. In 
order to avoid any potential conflicts, itis highly recommended that you 
specify a directory that does not already exist 


Where Would You Like to Install MyEclipse 6.0.17 
$ \Progran Files\yclipse 6.0 


se 2 
boe Restore Default Folder Choose. 
^ Install Complete 


atrovision 


Cancel 


图 1-28 MyEclipse 安装 路 径 选 择 界 面 


(4) 启动 MyEclipse, 首 先 要 选择 MyEclipse 的 工作 空间 ,工作 空间 存放 项 目 文件 和 
一 些 配 置信 息 , 这 里 选择 D:\Program Files\Apache Software Foundation\Tomcat 6. 0\ 
webapps 作为 工作 空间 ,如 图 1-29 所 示 。 启 动 以 后 页 面 如 图 1-30 所 示 。 


ce Launcher 


Select a workspace 
MyEclipse Enterprise Workbench stores your projects in a folder called a workspace. 


Choose a workspace folder to use for this session. 


Workspace: [D:\Program Files\Apache Software Foundation\Tomeat 6. O\webapps m| 


口 Use this as the default and do not ask again 


1-29 MyEclipse 的 工作 空间 设置 界面 


Java Enterprise — MyEclipse Enterprise Workbench TOK 
Bile Edit Navigate Search Project MyEclipse Eun Window Help 
Ci Welcome /.. 


Quick Update: (6%) 


图 1-30 MyEclipse 工作 界面 


132 在 WEclipse 中 配置 Torat 服务 器 


(1) 启动 MyEclipse 之 后 选择 MyEclipse 菜单 的 Preferences 选项 ,如 图 1-31 所 示 。 


弹出 Preferences 对 话 框 如 图 1-32 所 示 , 打 开 MyEclipse PE Wo ip 一 
左 侧 的 加 号 。 Project Capabilities , 
(2) 打开 MyEclipse 下 面 的 Servers 左 侧 的 加 号 ， |7 Examples On-Demand... 


Subscription Information... 


找到 Tomcat ,选择 你 所 安装 的 Tomcat 对 应 的 版 本 ,如 oe 
图 1-33 所 示 ,选择 了 Tomcat 5. x, 对 话 框 右 侧 出 现 对 应 Installation Summary... 

的 可 设置 项 目 , 单 击 Tomcat home directory 右边 的 Utilities : 
Browse 按钮 ,弹出 对 话 框 如 图 1-34 所 示 , 选择 本 机 Support 
Tomcat 的 安装 路 径 , 选 到 Tomcat 文件 夹 为 止 ,然后 单 图 1-31 选择 MyEclipse 菜单 的 


击 “ 确 定 ” 按 钮 。 Preferences 选项 


™Preferences (Filtered) 


type filter text w  MyEclipse 
# General 


= DES 
= AJAX 


Community Essent: SP 
Database Explore: AU 


Files and Editor: MyEclipse 


# Internet Tools ry 

& Java Enterprise | Enterprise Workbench 6.0 ye 
* 

g 


Project Capabili 
Servers 
Subscription 
a Tapestry (Spindl 
Waite My&clipse Enterprise Workbench 
a i i Clipse iterprise Workbencl 
Dem Copyright 2002-2007, Genuitec LLC 
$ Run/Debug Version: 6.0.1 GÀ 
Build Id: 6. 0. 1-6A-200710 


Installation root: 
D:\Program FilesWlyEclipse 6. 0\myeclipse 


图 1-32 Preferences 对 话 框 


®Preferences (Filtered) 


type filter text w Tomcat 5.x 
& Project Capabilities |&| To 


= Servers O Enable 
@Disable 


erver 


$ Geronimo 
# Glassfish 

& Integrated Sandbox 
s JBoss 

$ Jetty Tomcat base directory: 
= JOnAS : 

a JRun Tomcat tenp directory: 


Tomcat home directory: 


# Oracle Optional program arguments: 
# Orion 
由 Resin 
& Sun Java System Apr 
@ Tomcat 

E Tomcat 4.x 

s Tomcat 

由 Tomcat 6.x 
# WebLogic 
# WebSphere 
Subscription 

y (Spindle) 


Restore Defaults Apply 


1-33 ”选择 本 机 安装 的 Tomcat 版 本 


(3) 设置 好 Tomcat home directory 之 后 , 下面 两 项 Tomcat base directory 和 
Tomcat temp directory 自动 识别 ,然后 把 上 面 的 单 选 按钮 改 为 Enable, 如 图 1-35 所 示 。 


= © Program Files 
s C2 360 
© 360Apps 
a © Ahead 
5 © Apache Software Foun 
> OR 


Obin 
© common 
© conf 
Q logs 
© server 
© shared 
© tem 
a © webapps 
& © work 
# © Burn60 
@ C3 Cisco Packet Tracer 
& © Collegesoft 
< 


AHR: [Tees 5.5 


文件 天 四 | 


Caz 


图 1-34 选择 Tomcat 安装 的 路 径 


®Preferences (Filtered) 


type filter text 
# Files and Editors 
# Internet Tools 
# Java Enterprise Proje 
# Project Capabilities 
E Servers 
& Geronimo 
& Glassfish 
& Integrated Sandbox 
$ JBoss 
i$ Jetty 
w JOnAS 
& JRun 
# Oracle 
$ Orion 
& Resin 
& Sun Java System Apr 
= Tomcat 


& WebLogic 
i WehSnhere 
a 


3 


Tomat 5.x 


Tomcat server 

CO Enable 

ODisable 
Tomcat home directory: D:\Program Files\Apache 
D:\Program Files\Apache 


D:\Program Files\Apache 


Tomcat base directory: 


Tomcat temp directory: 
Optional program arguments: 


Restore Defaults 


1-35 i£ E Tomcat server 为 可 用 状态 


(4) 以 上 Tomcat 设置 好 了 ,下 面 打开 Tomcat 左 侧 加 号 ,如 图 1-36 所 示 , 开 始 设置 
IDK, i Add 按钮 ,弹出 对 话 框 Tomcat > Add JVM, 如 图 1-37 所 示 , 在 这 里 要 指定 
JRE home directory, 单 击 Browse 按钮 ,在 “浏览 文件 夹 ” 对 话 框 中 选择 ,Java 安装 路 径 下 
的 jdk 文件 夹 , 如 图 1-38 所 示 。 


® Preferences (Filtered) 


type filter text à JDK 


ë Java Enterprise Projeli 
$ Project Capabilities — 
Geronimo MyEclipse 6.0 
$ Glassfish Optional Java WE arguments: 
$ Integrated Sandbox 
is JBoss 
= Jetty 
w JOnAS 
i JRun 


= Oracle 


Tomcat JDK nane: 


JDE Virtual Machine must specify a full JDK installation. 


Java System Apr Specifying a JRE will result in an startup exception. 


$ Tomcat 
@Tomat 4.x E Avoid use of the -cp, -classpath, or -Djava.library.path JVM options. 
@Tomat 5.x Consult the Classpsth page for proper path configuration. 
Des 6x 
Launch 
Paths 


Restore Defaults 
Cla) 


图 1-36 i& E Tomcat 对 应 的 JDK 


f? Tomcat > Add JVM 


Select the root directory of the JRE 
JRE type: Standard VK EYES z 


Miet Cisco Packet Tracer A 
IRE home directory: © Col legesoft 

D FreeTime 

Default YH Arguments: (2 TAR Systems 


JRE system libraries: 


Add External JARs... 


& C3 demo 
a © include 
& © jre 
e © lib 
& © sample 
Q Kies 
© linux 
$ © Microsoft ActiveSync 
"Soertee 
# © RenRen 
< 


mR: [dk 6.0 19 


图 1-37 添加 JVM 图 1-38 找到 Java 安装 路 径 下 的 
jdk 文件 夹 


(5) 选择 好 路 径 之 后 JRE name 和 JRE system libraries 自动 识别 ,如 图 1-39 所 示 ， 
单 击 OK 按钮 ,至 此 ,JDK 设置 完毕 ,如 图 1-40 所 示 , 单 击 OK 按钮 。 

(6) 所 有 关于 MyEclipse 中 服务 器 的 配置 完成 ,图 1-41 中 Tomcat 5. x 就 是 刚刚 添加 
好 的 服务 器 ,现在 它 还 处 于 停止 状态 ,运行 服务 器 ,如 图 1-42 所 示 服 务 器 正常 启动 。 


f Tomcat > Add JVM 


JRE type: [Stand 

JRE name: jdk1. 6. 

IRE home directory: [D:\Program Files Ja 

Default Vl Arguments: 

JRE system libraries: 

| = £3 D:\Program Files\Java\ jdkl. 6. 0|[Add External JARs... 

| @ £3 D:\Program Files\Java\jdkl. 6.0 
a D:\Program Files\Java\ jdkl. 6.0 

& & D:\Program Files\Java\jdkl. 6.0 

$ & D:\Program Files\Java\jdkl. 6. 0 

ağ D:\Program Files\Java\ jdkl. 6.0 

# #) D:\Program Files\Java\ jdkl. 6.0 

# $ D:\Program Files\Java\jdkl. 6. 0 

# #) D:\Program Files\Java\ jakl. 6. 0 

8 #) D:\Program Files\Java\ jdkl. 6.0 


Restore Default 


f Preferences (Filtered) 
type filter text JDK 
= Servers 

# Geronimo 
# Glassfish 

* Integrated Sandbo Jel. 6 

# JBoss Optional Java VE arguments: 
a Jetty 

* JOnAS 

*$ JRun 

5 Oracle 

$ Orion 

® Resin 

# Sun Java System As Notes 


Tomcat JDK name: 


JDK Virtual Machine must specify a full JDK installation. 
Specifying a JRE will result in an startup exception. 


Avoid use of the -cp, -classpath, or -Djava. library. path JVI options. 
Consult the Classpath page for proper path configuration. 


# WebLogic 
# WebSphere 
Suha; " 


Restore Defuls]| — Apply 


图 1-40 JDK 设置 完毕 


Problens [iit Servers ii. © Console 9 Web Browser) v OF tmx zp 
Server Hode Location 
| A MyEclipse Derby 
@ ItyEclipse Tomcat 
Ta 5.x 


图 1-41 成 功 添 加 Tomcat 5. x 


o (msma) 0000 


Problems W Servers E)Console (i .. 9 Web Browser EI B-ri-"H 


tomcat6Server [Remote Java Application] D:\Program Files\Java\jdkl. 6.0 19WbinVjavew.exe (Feb 9, 201, 
2015-2-9 16 


plicaticnContext log 


| 信息 : Find regist: 
2 s 16 


Æ 1-42 4 MyEclipse Tomcat 5. x 正常 运行 


133 使 用 MyEclipse 创建 第 一 个 Jp 程序 


CD 启动 MyEclipse, 首 先 调整 工作 空间 为 Tomcat 的 ROOT 目录 下 ,如 图 1-43 所 
示 , 以 后 的 工作 空间 都 以 此 为 准 。 


f Workspace Launcher 
Select a workspace 


MyEclipse Enterprise Workbench stores your projects in a folder called a workspace. 
Choose a workspace folder to use for this session. 


? Copy Settings 


图 1-43 设置 工作 空间 为 Tomcat 的 ROOT 目录 下 


(2) 启动 MyEclipse 工具 ,新 建 一 个 工程 , File-New-Web Project. 弹出 New Web 
Project 窗口 ,如 图 1-44 所 示 ,Project Name 设置 为 h, 然 后 单 击 Finish 按钮 完成 工程 的 新 建 。 


®New Web Project 
Create a Web Project 


Create a web project in the workspace or an external location 


Web Project Details 
Project Name h 
Location 回 Use default location 


Source folder src 
Web root folder WebRoot 
Context root URL /h 


J2EE Specification Level 
©ffava KE 5.0 OT2EE 1.4 OT28E 1.3 


JSIL Support 


图 1-44 新 建 一 个 工程 h 


(3) 在 服务 器 中 添加 刚刚 建立 好 的 工程 h, 单 击 图 1-45 中 的 按钮 ,就 会 弹出 Server 
Deployments 对 话 框 ,如 图 1-46 所 示 , 单 击 右 侧 的 Add 按钮 。 


区 Problems (fib Servers £3. © Console 9 Web Browser ICE ETI ETIESE 
| Server Status Wode Location | 
# lyEclipse Derby f Stopped 
A MyEclipse Tomcat fl Stopped 


>| 


图 1-45 向 服务 器 中 添加 新 建 的 工程 


f Server Deployments 


Manage Deployments 
Deploy and undeploy J2EE projects. 


Server|Tomcat 5.x hd 
Deployments 


Project Type Location 
j Exploded D:\Program Files\Apache Software 
Exploded D:\Program Files\Apache Software 
VB jsp-3 Exploded D:\Program Files\Apache Software 


| 国 > 
Deployment Status 


图 1-46 Server Deployments 对 话 框 


(4) 弹出 New Deployment 对 话 框 ,选择 需要 添加 的 工程 ,如 图 1-47 所 示 ,然后 单 击 
Finish 按钮 就 会 看 到 选择 的 工程 h 已 经 添加 到 了 Deployments 列表 中 ,如 图 1-48 所 示 ， 
单 击 OK 按钮 。 

(5) 现在 在 Server 标签 中 已 经 可 以 看 到 工程 h 已 经 在 运行 的 服务 器 下 了 ,如 图 1-49 
所 示 ,然后 转换 到 Web Browser 标签 ,在 地 址 栏 输入 地 址 http://127. 0. 0. 1:8080/h 就 可 
以 看 到 我 们 的 第 一 个 ISP 工程 的 运行 了 ,如 图 1-50 所 示 ,这 个 是 项 目 创建 时 自动 生成 的 
默认 首页 。 


®New Deployment 


New Deployment 


Create new project deployment for Tomcat 5.x 


Server: Tomat 5.x 
Project: s 
Edit server connectors... 

Deploy type: 


?Exbloded Archive (development mode) O Packaged Archive (production mode) 


Deploy Location: [D:\Program Files\Apache Software Foundation\Tomcat 5.5\webapps\h) 


图 1-47 New Deployment 对 话 框 选择 h 工程 


f Server Deployments 


Nanage Deployments 
Deploy and undeploy J2EE projects. 


Server|Tomcat 5.x 
Deployments 


Project Type Location 
Weg 


Exploded D:\Program Files\Apache Software 


vB jsp-4 Exploded D:\Program Files\Apache Software | Remove 
"m Exploded D:\Program Files\Apache Software 


t 
vB jsp-3 Exploded D:\Program Files\Apache Software | [__Redeploy | 


€ > Browse 


Deployment Status 
Successfully deployed. 


图 1-48 工程 h 已 经 添加 到 了 Deployments 列表 


si Servers h, E Console 9 Web Browser 
S 

# Mykclipse Derby 
A MyEclipse Tomcat 


Tode Loca 


Sağ Tomcat 5.x [default] ORn 
iss © Exploded D:\Program Files\Apache Software Founda... 
wh © Exploded D:\Program Files\Apache Software Founda... 
Bt © Exploded D:\Program Files\Apache Software Founda... 
Biss 


G Exploded D:\Program Files\Apache Software Founda... 


图 1-49 工程 h 已 经 在 服务 器 中 运行 


[情境 一 J5P 的 环境 配置 与 开发 工具 | 


[È Problems | # Servers E Console 9 Web Browser ©). 2 e@e- =O 
Location http://127. 0. 0. 1:8080// «o 
| 


This is my JSP page. 


图 1-50 在 浏览 器 中 测试 工程 


1.4 设置 Web 服务 目录 


141 Web ARS Bo 


Web 服务 目录 就 是 用 户 浏览 器 能 够 访问 的 页 面 所 在 的 目录 。 如 果 要 发 布 网 页 ,必须 
将 编写 好 的 JSP 页 面 放 到 Web 服务 目录 中 。 在 本 章 中 安装 的 Tomcat 的 根 目 录 在 服务 
器 上 的 路 径 为 D:\Program Files\Apache Software Foundation\ Tomcat 6. 0\webapps\ 
ROOT. webapps 子 目录 下 除了 ROOT 以 外 ,还 有 docs, examples, manager 等 子 目录 ， 
这 些 子 目 录 也 是 可 以 被 访问 的 ,比如 ,在 浏览 器 的 地 址 栏 输入 http://127. 0. 0. 1:8080/ 
docs/apr. html, 就 可 以 访问 docs 子 目 录 中 的 apr. html 文件 。 除 了 这 些 默 认 安 装 的 服务 
子 目录 以 外 ,用 户 还 可 以 在 webapps 目录 中 创建 新 的 子 目录 .例如 ,上 一 节 中 建立 的 h 项 
目 就 是 与 webapps 目录 并 列 的 子 目录 。 


142 增加 虚拟 服务 目录 


除了 在 安装 目录 中 的 webapps 目录 下 创建 Web 服务 子 目 录 外 ,如 果 想 在 一 个 方便 的 
目录 下 存放 Web 项 目 .那么 就 可 以 通过 增加 虚拟 服务 目录 的 方法 来 解决 。 首 先 打开 D:\ 
Program Files\Apache Software Foundation\Tomcat 6, 0\conf 路 径 下 的 server. xml, 在 
文件 倒数 第 四 行 找到 二 /host> .在 其 前 面 插入 语句 : 

<Context path="/test" docBase="d:\test\" debug="0" reloadable="true"> 

</Context> 

FP. path="/test" Jj HE W H R4 fi. docBase— "d: NtestV" 2g. Web MSF ARH 
理 路 径 。 最 后 保存 并 关闭 server. xml 文件 ,重启 Tomcat, d£ E — WHA Web WA 
制 到 d:\test\ 目 录 下 。 

在 浏览 器 的 地 址 栏 输入 http://127. 0. 0. 1:8080/test/h/WebRoot/index. jsp. 如果 
出 现 如 图 1-34 所 示 的 页 面 , 即 为 修改 成 功 。 


本 章 小 结 


通过 本 章 的 学 习 , 应 基本 了 解 JSP 的 概念 技术 特点 、 运 行 原理 .JSP、JavaBean 和 
Java Servlet 的 关系 ,掌握 搭建 JSP 运行 环境 的 方法 ,以 及 JSP 开发 工具 的 安装 和 使 用 ,为 


| >) j (mews is) 0 m 


后 续 的 学 习 打 下 基础 。 


ABD a 


一 、 选 择 题 
l. 当 用 户 请 求 JSP 页 面 时 ,JSP 引擎 就 会 执行 该 页 面 的 字 节 码 文件 响应 客户 的 请 
OR ,执行 字 节 码 文件 的 结果 是 (  )。 


A. 发 送 一 个 JSP 源 文件 到 客户 端 B. 发 送 一 个 Java 文件 到 客户 端 
C. 发 送 一 个 HTML 页 面 到 客户 端 D. 什么 都 不 做 

2. 当 多 个 用 户 请 求 同 一 个 JSP 页 面 时 ,Tomcat 服务 器 为 每 个 客户 启动 一 个 ( Ws 
A, 进程 B. 线程 C. 程序 D. 服务 


3. 下 列 动态 网 页 和 静态 网 页 的 根本 区 别 描述 错误 的 是 ( Ja 
. 静态 网 页 服务 器 端 返回 的 HTML 文件 是 事先 存储 好 的 
. 动态 网 页 服务 器 端 返回 的 HTML 文件 是 程序 生成 的 
. 静态 网 页 文件 里 只 有 HTML 标记 ,没有 程序 代码 
.动态 网 页 中 只 有 程序 ,不 能 有 HTML 代码 
) 不 是 JSP 运行 必需 的 。 
.操作 系统 B. JavaJDK 
.支持 Jsp 的 Web 服务 器 D. 数据 库 
5. URL 是 Internet 中 资源 的 命名 机 制 ,URL 由 ( ) 三 部 分 构成 。 
A. 协议 .主机 DNS 名 或 IP 地 址 和 文件 名 
B. 主机 .DNS 名 或 卫 地址 和 文件 名 、 协 议 
C. 协议 ,文件 名 主机 名 
D. 协议 文件 名 IP 地 址 
6. 下 列 说 法 中 ( ) 是 正确 的 。 
A. Apache 用 于 ASP 技术 所 开发 网 站 的 服务 器 
B. IIS 用 于 CGI 技术 所 开发 网 站 的 服务 器 
C. Tomcat 用 于 JSP 技术 所 开发 网 站 的 服务 器 
D. WebLogic 用 于 PHP 技术 所 开发 网 站 的 服务 器 
. Tomcat 服务 器 的 默认 端口 号 是 ( Js 
A. 80 B. 8080 €. 21 D. 2121 
二 、 简 答题 
1. 为 什么 要 为 JDK 设置 环境 变量 ? 
2. Tomcat 和 JDK 是 什么 关系 ? 
3. 什么 是 Web 服务 根 目录 、 子 目录 、 相 对 目录 ? 如 何 配置 虚拟 目录 ? 


O»B^Un0wv- 


=y 


ee 


本 章 将 为 大 家 介绍 HTML 的 结构 和 常用 的 标记 ,这 是 为 了 让 大 家 更 加 了 解 我 们 使 
用 网 页 设计 工具 生成 的 页 面 代码 所 代表 的 含义 。 

本 章 学 习 的 目的 与 要 求 是 掌握 HTML 网 页 中 表格 标记 、 文 本 标记 、 链 接 标 记 等 常用 
标记 的 结构 和 写法 。 


2.1 常用 HTML 标记 


实战 演练 全 一 段落 标记 


【题目 】 

本 题目 要 求 使 用 段落 标记 输出 三 行文 字 , 对 齐 方式 分 别 为 居中 、 左 对 齐 、 右 对 齐 , 男 外 
再 输出 一 个 标尺 线 。 

【分 析 】 

本 例题 是 对 于 HTML 常用 标记 的 一 个 体验 练习 ,在 这 个 例题 中 向 大 家 展示 一 个 
HTML 网 页 的 文档 结构 ,并且 应 用 到 了 标题 栏 一 title 之 段落 二 p> .换行 二 br 过、 标尺 线 
二 hr 二 标记 。 效 果 如 图 2-1 所 示 。 

> 标题 栏 标记 的 使 用 ， 将 显示 在 浏览 器 窗口 标题 栏 
SPF Row On fe BCR Q BR a 
.. Cilicrosoft 网 站 ^ SHAM... OFF ë ” ORTL 


段落 标记 的 使 用 , 段落 居中 对 齐 ， 下 面 是 标尺 线 标记 的 使 用 


县 落 标记 的 使 用 , 段落 左 对 齐 。 


段落 标记 的 使 用 , 段落 右 对 齐 。 这 个 段落 前 加 入 了 三 个 换行 标记 。 
图 日 皮肤 > OTS SAREE Vaq- 


图 2-1 段落 标记 运行 效果 网 页 
【 源 代码 】 


1 <html> 
2 二 head 二 <title> 标 题 栏 标记 的 使 用 ,将 显示 在 浏览 器 窗口 标题 栏 </title></head 
3 <body text=" #666666" bgcolor=" # FFCCFF"> 


> (asmi weise] 7 


4 <p align="center" > Bt f fg ie (0 f JH RRSP MA, F il deb Ab ie 09 E 

5 <hr size="2" width=80%> 

6 <p align="left"> BE tric HE, RAMA. 

7 «br /><br /><br /> 

8 <p align— "right" BREN, BRAM. KTR HMA THR TiC. 
9 </body> 
10 </html> 
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1. HTML 介绍 


HTML 是 英文 Hyper Text Markup Language 的 缩写 , 即 超 文本 标志 语言 ,所 谓 超 文 
本 ,是 因为 它 可 以 加 入 图 片 \ 声 音 动画 .影视 等 内 容 。 用 它 编写 的 文件 (文档 ) 的 扩展 名 
是 . html Bk. htm, 可 供 浏览 器 解释 浏览 。 可 以 使 用 记事 本 、Dreamweaver 或 MyEclipse 等 
编辑 工具 来 编写 HTML 文件 。HTML 语言 通常 使 用 二 标志 名 之 过 /标志 名 之 来 表示 标 
志 的 开始 和 结束 (例如 二 html 二 二 /html 二 标志 对 ), 因 此 在 HTML 文档 中 这 样 的 标志 对 
都 必须 是 成 对 使 用 的 。 


2. HTML 文档 基本 结构 


一 个 HTML 文档 由 一 系列 的 元 素 和 标签 组 成 。 元 素 名 不 区 分 大 小 写 。HTML 用 标 
签 来 规定 元 素 的 属性 和 它 在 文件 中 的 位 置 , HTML 超 文 本 文档 分 文档 头 和 文档 体 两 部 
分 ,在 文档 头 里 ,对 这 个 文档 进行 了 一 些 必 要 的 定义 ,文档 体 才 是 要 显示 的 各 种 文档 信息 。 

(1) <html></html> 

<html> f HIT. HTML 文档 的 最 前 边 , 用 来 标识 HTML XFA, </html> 
标志 放 在 HTML 文档 的 最 后 边 , 用 来 标识 HTML 文档 的 结束 ,两 个 标志 必须 同时 使 用 。 

(2) <head></head> 

<head> fl </head> Hj JK HTML 文档 的 开头 部 分 ,在 此 标志 对 之 间 可 以 使 用 
<title>< /title>.<script ></script>“ fg ai XJ . 3X HE bp OT OBA HGR HTML X 
PY AY AR fei E <head> </head> frp aki Xt Z [8] HI PY A AE AS Ze CE UI V D EE Pas tH OK 
的 。 两 个 标志 必须 同时 使 用 。 

(3) <body></body> 

<body> </body> # HTML 文档 的 主体 部 分 ,在 此 标志 对 之 间 可 包含 一 p 二 、 
</p>, <h>, 二 /hl>、 < 二 br>、 二 hr> 等 众多 的 标志 ,它们 所 定义 的 文本 、 图 像 等 将 会 
在 浏览 器 的 框 内 显示 出 来 。 两 个 标志 必须 同时 使 用 。 

(4) <title></title> 

使 用 过 浏览 器 的 人 可 能 都 会 注意 到 浏览 器 窗口 最 上 边 蓝 色 部 分 显示 的 文本 信息 , 那 
些 信息 一 般 是 网 页 的 “主题 ", 要 将 网 页 的 主题 显示 到 浏览 器 的 顶部 其 实 很 简单 ,只 要 在 
<title 之 二 /title 之 标志 对 之 间 加 入 想 要 显示 的 文本 即 可 。 注 意 : <title >< /title> by 
XI R REG TE <head> </head> trai MZ I). 
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1. HTML 的 标签 与 属性 


HTML 的 标签 有 单 标签 和 成 对 标签 两 种 。 成 对 标签 是 由 首 标 签 过 标签 名 之 和 尾 标 
签 二 /标签 名 之 组 成 的 ,成 对 标签 的 作用 域 只 作用 于 这 对 标签 中 的 文档 。 单 独 标签 二 标签 
名 二 在 相应 的 位 置 插入 元 素 就 可 以 了 ,大 多 数 标签 都 有 自己 的 一 些 属性 ,属性 要 写 在 首 标 
签 内 ,属性 用 于 进一步 改变 显示 的 效果 ,各 属性 之 间 无 先后 次 序 , 属 性 是 可 选 的 ,属性 也 可 
以 省 略 而 采用 默认 值 ,其 格式 如 下 : 


二 标签 名 字 属 性 1 属性 2 属性 3 … 内容 /标签 名 字 二 


作为 一 般 的 原则 ,大 多 数 属性 值 不 用 加 双 引 号 。 但 是 包括 空格 、%、# 等 特殊 字符 的 
属性 值 必须 加 入 双 引 号 。 如 : 


<body text=" #666666" bgcolor=" # FFCCFF"> 


HER. 输入 始 标签 时 ,一 定 不 要 在 二 ”与 标签 名 之 间 输 入 多 余 的 空格 ,也 不 能 在 中 文 
输入 法 状态 下 输入 这 些 标签 及 属性 ,否则 浏览 器 将 不 能 正确 地 识别 括号 中 的 标志 命令 ,从 
而 无 法 正确 地 显示 你 的 信息 。 


2. HTML 的 主要 标记 一 一 文字 布局 
(1) 行 的 控制 

换 段 标记 格式 : 

<p algin=BX>...</p> 

换行 标记 格式 : 

<br> 

不 换行 标记 格式 : 

<nobr> 


<p> </p> HRT XI E HK 8] ££ — A BEA «de MC SE VTA BY CA ez Bee 
的 格式 显示 在 浏览 器 上 。 

(2) 文字 对 齐 

algin 属性 是 标记 的 对 齐 属性 ,通过 设置 它 的 值 可 以 对 齐 标记 中 的 内 容 ,如 二 p align= 
"center" 二 段落 标记 的 使 用 ,段落 居中 对 齐 二 /p 二 。 另 外 ,还 可 以 通过 一 center 二 标记 对 
文本 在 页 面 中 进行 居中 显示 。 


实战 演练 2 一 一 在 网 页 中 使 用 各 种 文本 格式 


【题目 】 
本 题目 是 对 于 网 页 中 常用 文本 标记 的 使 用 示范 。 
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【分 析 】 
在 这 个 练习 中 应 用 到 了 标题 一 hl 二 二 h2 之 二 h3 过 标记 、 粗 体 一 b>、 斜 体 二 ji 一 、 下 划 
<u>, ER <sub>, Fin<sup>4tric. SCR WA 2-2 Bm. 


关于 文字 祭 忆 的 示例 - 2245 MORARI 文件 aE 收藏 IR BH FY 一 O X 
e C Q  Botpy127001: +> Q E.-:Q à W- 
bea- Natam bue Dean 口 Dell D mMykdi wo ERG 
D E 关于 文字 标记 的 示例 x | 十 A Ktu 


情境 2 一 一 Web 开发 基础 (标题 1) 


月 下 独 柄 一 -李白 标题 2) 

下 面 这 段 文字 字体 Arial， 字 号 4， 颜 色 *99CC00 
defo wei, BURGH: = CLAD 

举 杯 邀 明月 ， 对 影 成 三 人 。 《下 划 线 》 
HUA, BERG. (PE 


使 用 下 标 表示 一 个 化 学 分 子 式 ，《〈 标 题 37 
NaCO; 
使 用 上 标 表 示 S 的 立方 ，〔 标 题 3) 


[OE w © Go @ 100% ~ 
图 2-2 文字 标记 运行 效果 网 页 
【 源 代码 】 


1 <html> 

2 «head? title X T MF br id (f A fl </title></head> 

3 <body> 

4 ”二 hl 二 > 情境 2—— Web 开发 基础 (标题 1) —/h17 

5 <<h2> 月 下 独 酌 一 一 李白 (标题 2)<</h2 之 

6 <font face=" Arial" size="4" color=" # 99CC00" > 

7 p X BOCIESE MK Arial, FẸ 4, BE #99CC00</p> 

8 <p> <b> Zé ie] — 338 , TR RO JC GR ; CHL) </b></p> 
9 <p> <u% WA EREA, CR RMR)</u></p> 
10 <p><i> AA MK, BERR. CBK)</i></p> 
11 </font> 

12 二 h3> 使 用 下 标 表 示 一 个 化 学 分 子 式 : (标题 3)</h3> 

13 <font size="6"> 

14 <p><b>NaCO<sub>3</sub></b></p> 

15 </font> 

16 —h32 fH] E fs S 的 立方 : CRE 3)</h3> 

17 <p><b>S<sup>3</sup></b></p> 

18 </body> 

19 </html> 


213 HM 的 主要 标记 字体 标记 
l. 标题 字体 
标题 字体 标记 的 格式 : 


<h# align=BR>... </h# 二 其 中 # —1,2,3,4,5,6 


标签 用 于 设置 网 页 中 的 标题 文字 ,被 设置 的 文字 将 以 黑体 或 粗 体 的 方式 显示 在 网 页 
中 。 其 参数 为 left( 左 )，enter( 中 )，right ( 右 ) ,如 上 面 的 例题 中 用 到 的 ,二 h2 之 月 下 独 
B — FARA 2) /h27 , 


2. 字体 格式 


二 FONT> 标 签 用 于 控制 文字 的 字体 ,大 小 和 颜色 。 控 制 方式 是 利用 属性 设置 得 以 
实现 的 ,格式 如 下 : 


<font face=# 1 size=#2 color= #3>...</font> 


face 属性 设置 文字 使 用 的 字体 ,如 果 用 户 的 系统 中 没有 face 属性 所 指 的 字体 , 则 将 
使 用 默认 字体 。size 属性 的 取 值 为 1~~7, 也 可 以 用 “十 ”或 “一 ”来 设 定 字号 的 相对 值 。 
color 属性 的 值 为 : rgb Bf # nnnnnn 或 颜色 的 名 称 。 如 上 面 的 例题 中 用 到 的 ,二 font 
face=" Arial" size="4" color=" # 99CC00" >, 


3. 字体 样式 


在 有 关 文 字 的 显示 中 ,常常 会 使 用 一 些 特殊 的 字形 或 字体 来 强调 、 突 出 .区 别 以 达到 
提示 的 效果 。 

粗 体 字 : 二 p 二 一 b> 花 间 一 壶 酒 , 独 酌 无 相亲 ; CHLAO — / bo — /p— 

下 划 线 : 二 p 二 二 u 二 举 杯 邀 明月 ,对 影 成 三 人 。( 下 划 线 ) 二 /u 二 二 /p 二 

THESE: <p><i> A BEA RIK GEBTE ER. CRHAO </i> </p> 

带 下 标的 : <p><b>NaCO<sub>3</sub></b></p> 

带 上 标的 : <p><b>S<sup>3</sup></b></p> 

还 有 一 些 举例 ; 

二 em 二 用 于 强调 的 文本 ,一 般 显 示 为 斜体 字 二 /em 二 

< 一 strong 二 用 于 特别 强调 的 文本 ,显示 为 粗 体 字 一 /strong 盖 

< 到 cite 之 用 于 引证 和 举例 ,通常 是 斜体 字 二 /cite 二 

<code> FAK 48 th 3x J& — 28 [V8 — / code 

—small >H 4E SCA Wi) F lib zR — / small 

<big> ME SCA& LU EE bos — / big 

<samp> li zs — Beit SEBURE FH BD A BI S BE RH AE 5 HS — / samp 

<kbd> Hi Hi P! fij A CA 38 86 Sos A BERL AY BE RE — / kbd- 

— var His sons EE . d bos BUA HE /var> 
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二 dfn 二 表示 一 个 定义 或 说 明 , 通 常 显示 为 斜体 字 二 /dfn 二 


2.2 HTML 的 表格 应 用 


实战 演练 和 全 一 表格 1 


【题目 】 

本 范例 介绍 如 何在 网 页 中 建立 一 个 基本 表格 。 
【分 析 】 

在 网 页 制作 中 表格 的 使 用 是 非常 普遍 的 ,可 以 说 在 网 页 的 世界 里 有 了 表格 才 有 了 规 
和 矩 。 在 整个 网 页 中 ,可 以 使 用 表格 来 划分 页 面 的 区 块 ,无 论 是 文字 或 图 片 都 可 以 在 表格 中 
找到 适当 的 位 置 摆 放 。 此 范例 介绍 了 在 网 页 中 


口 表格 

表格 的 基本 结构 以 及 使 用 方法 。 表格 使 用 | 一 ER 一 
ee ee a 
使 用 二 tr 二 表示 ,单元 格 使 用 二 td 二 表示 。 范 例 — — 
运行 效果 如 图 2-3 所 示 。 图 2-3 “在 网 页 中 建立 的 一 个 基本 表格 
【 源 代码 】 

1 <html> 

2 <head><title># ft </title></head> 

3 <body> 

4 <center> 

5 <table border="1"> 

6 xu 

d ho 9 </th> 

8 二 了 th 二 姓名 二 /th 

9 hd tih 

10 <th> Bre bo BE</th> 

11 </tr> 

120 <tr> 

13 <td>01</td> 

14 td iki </td> 

15 <td> </td> 

16 <td> KER T BU BORA BE</td> 

17 «fü 

18 <tr> 

19 <td>02</td> 

20 <td> Bii </td> 

21 <td> </td> 

22 二 td 二 天 津 轻 工 职业 技术 学 院 二 /td 二 

23 </tr> 


24 </table> 
25 </center> 
26 </body> 
27 </html> 


221 定义 表格 的 基本 语法 


表格 标志 对 于 制作 网 页 是 很 重要 的 ,主要 是 因为 表格 不 但 可 以 固定 文本 或 图 像 的 输 
出 ,而 且 还 可 以 任意 地 进行 背景 和 前 景 颜色 的 设置 。 
定义 表格 的 格式 如 下 : 


<table> 


</table> 


5E UK T HI t — / t 4E XU HI <th></th>, eM HCH HE — td></td>. 
在 一 个 最 基本 的 表格 中 UBL — 4 <table> b 4€ .— A b 48 — tr FH A <td> b E 
或 二 th 二 标签 。 使 用 方法 如 上 面 例题 所 示 。 


222 单元 格 内 文字 布局 


文字 在 表格 中 的 布局 包括 水 平方 向 和 垂直 方向 两 种 。 它 们 的 语法 如 下 所 述 。 
水 平方 向 : 


<tr align 一 参数 > </tr> 
<th align 一 参数 > </th> 
<td align 一 参数 > </td> 
2 — left ,center \right。 
垂直 方向 : 

<tr valign= A> </tr> 


<th valign 一 参数 > </th> 
<td valign=BR> </td> 


2 = top, middle, bottom, baseline. 
实战 演练 2 一 表格 2 


【题目 】 
本 范例 介绍 如 何在 表格 中 实现 跨行 、 跨 列 的 操作 。 
【分 析 】 
在 日 常 的 表格 应 用 当中 ,跨行 或 跨 列 的 操作 非常 普遍 ,那么 在 网 页 中 要 如 何 完 成 这 样 
的 操作 呢 ? 实现 跨行 的 方法 是 在 行 的 属性 中 加 入 colspan; 实现 跨 列 的 方法 是 在 列 的 属 
性 中 加 入 rowspan。 本 题目 运行 效果 如 图 2-4 所 示 。 
[/ 口 跨行 、 跨 列 (= 


基本 信息 所 在 院 校 
编号 “姓名 UM 
c (sae ARE DNR 


02 d 5 


2-4 ”跨行 、 跨 列 操作 示例 
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【 源 代码 】 
1 <html> 
2 «head «title 2547 8531 — / title </head> 
3 <body> 
4 <table width="350"  bordercolor— " # CCCCCC" heigth= "290" border— "8" align="center" 
cellpadding— "4" cells5  pacing— "2"> 
5 <tr > 
6 <th colspan="3" bgcolor=" € FFFF99">2£4 fri &</th> 
7 <th width="132" align="center" valign="middle" bgcolor=" # FFFF99" > fjr TE Bi Ez 
</th> 
8 </tr> 
9 <tr > 
10 <th width= "36" > 44 5 — /th— 
11 <th width= "49" > H4 </th> 
12 <th width= "63" > HEJ] </th> 
13 <td rowspan="3" align="center" valign="middle" > X £e TW HERF BE </td> 
14 </tr> 
15 <tr> 
16 <td height="30" align="center" valign="middle" >01</td> 
17 <td align="center" valign="middle" > </td> 
18 <td align="center" valign="middle" > </td> 
19 </tr> 
20 <tr> 
21 <td align="center" valign="middle" >02</td> 
22 <td align="center" valign="middle" > £718 lS </td> 
23 <td align="center" valign="middle" ></td> 
24 </tr> 
25 </table> 
26 </body> 
27 </html> 


223 跨 多 行 . 多 列 的 单元 格 


要 创建 跨 多 行 ,多 列 的 单元 格 , 只 需 在 二 th 二 或 二 td 二 中 加 入 rowspan 或 colspan 属 
性 的 属性 值 ,默认 值 为 1 ,该 属性 值 表明 了 表格 中 要 跨越 的 行 或 列 的 个 数 。 
跨 多 列 的 语法 : 


<th colspan= #> <td colspan= +> 


colspan 表示 跨越 的 列 数 , 如 colspan=2 表示 这 一 格 的 宽度 为 两 个 列 的 宽度 。 
跨 多 行 的 语法 : 


<th rowspan=#> <td rowspan= $+ > 
rowspan 表示 跨越 的 行 数 ,如 rowspan=2 表示 这 一 格 跨越 表格 两 个 行 的 高 度 。 
224 RERE 


在 HTML 3t ifi P . f FH Se Ft HE E HE oe ERK BD — 1 dei AERE RT LUCES 
一 个 表格 。 用 表格 来 排版 页 面 的 思路 是 : rh p AR LX E P ZA «n CES T i vx 


各 个 子 栏目 的 排版 ,并 插入 表格 的 相应 位 置 ,这 样 就 可 以 使 页 面 的 各 个 部 分 有 条 不 紊 、 互 不 
冲突 清晰 整洁 。 在 实际 做 网 页 时 一 般 不 显示 边框 ,边框 的 显示 可 根据 自己 的 爱好 来 设 定 。 


2.3 在 HTML 中 插入 图 像 和 超级 链接 


实战 演练 一 一 超级 链接 


【题目 】 


本 范例 介绍 网 页 中 图 片 的 添加 和 超级 链接 的 使 用 。 


【分 析 】 


在 此 例题 中 使 用 到 了 链接 标记 二 a href ></a> ,以 此 方法 链接 到 了 前 面 做 过 的 例题 
网 页 ,以 及 本 门 课程 精品 课 网 站 的 首页 ,还 有 邮件 链接 的 方法 。 在 这 个 网 页 中 我 们 还 使 用 
了 去 img/ 之 标记 添加 了 图 片 。 题 目 运行 效 果 如 图 2-5 所 示 。 


本 章 例题 链接 同一 目录 下 的 网 页 ) : 
ee 基本 网 页 结构 和 标记 
同文 字 标 记 例 题 
TIEA 
联系 我 们 : 


JSP 精 品 课 网 址 ，http://211. 81. 40. 73/dz/dtwz/index. asp 
发 邮件 ，sunqian_teacher@163. com 


图 2-5 插入 图 片 和 超级 链接 示例 


【 源 代码 】 

1 <html> 

2 <head><title>4fi A PAH AB t HE BE</title></head> 

3 <body> 

4 <table width="500" border— "0" align="center" cellpadding="0" cellspacing="0"> 

5 <tr> 

6 <td height="40" colspan="2" align="left" valign="middle"> 
本 章 例题 (链接 同一 目录 下 的 网 页 ): </td> 

7 </tr> 

8 <tr> 

9 <td width="150" align="right" ><img src="sub05_07. gif" width="23" height="20" /> 
</td> 

10 <td width="350" height="20"> 

11 <a href 一 "ch2-2. html" title="" target="_blank" > 4 4 sj vt 44 Hj Al brik </a> 

</td> 

12 </tr> 

13 <tr> 

14 <td align= "right" ><img src— "sub05 07.gif" width="23" height="20" /></td> 

15 <td height="20"><a href="ch2-3. html" title="" target="_blank" — 3X 5E fig ff] R8 


</a></td> 
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16 </tr> 

17 <tr> 

18 <td align="right" ><img src="sub05_07. gif" width="23" height="20" /></td> 
19 <td height="20"><a href— "ch2-6. html" title="" target="_blank" 之 基本 表格 例题 


</a></td> 
20 </tr> 
21 <tr> 


22 <td align="right"><img src— "sub05 07.gif" width— "23" height="20" /></td> 
23 <td height="20"><a href— "ch2-9. html" title="" target="_blank" 之 跨行 跨 列 例题 


</a></td> 
24 </tr> 
25 <tr> 
26 <td height="40" colspan="2" align="left" valign="middle" > RH]: </td> 
27 </tr> 
28 <tr> 


29 <td align="right">JSP 精品 课 网 址 : </td> 

30 <td height="20" ><a href 一 "http://211.81.40.73/dz/dtwz/index. asp" title— "" target — 
"_blank"> http://211.81.40.73/dz/dtwz/index.asp </a></td> 

31. </tr> 

32 <tr> 

33 <td align="right"> A lif: </td> 

34 <td height="20"> 

35 <a href= "mailto:sungian teacher(2 163. com" title=" " > sunqian_teacher@ 163. com</a> 
</td> 

36 </tr> 

37 </table> 

38 </body> 

39 </html> 


231 < im^ 表单 标记 


在 网 页 中 是 通过 过 img 盖 标记 的 属性 sec 将 图 像 插入 网 页 中 的 ,属性 src 的 值 可 以 是 
路 径 , 也 可 以 是 网 址 。 实 际 上 就 是 通过 路 径 将 图 形 文件 嵌入 文档 中 。 
插入 图 像 的 格式 为 


<img src= BR 1 alt 一 参数 2> 


属性 alt 设置 浏览 器 尚未 完全 读 入 图 像 时 ,在 图 像 位 置 显示 的 文字 。 
设置 图 像 和 文字 对 齐 的 格式 为 


<img align 二 参数 二 
HPA% = top. middle. bottom. left. right. 


232 < ahref> 标记 
1. 建立 超级 链接 
HTML 文件 中 最 重要 的 应 用 之 一 就 是 超级 链接 .超级 链接 是 一 个 网 站 的 灵魂 。 超 文 


本 具有 的 链接 能 力 , 可 层 层 链接 相关 文件 ,这 种 具有 超级 链接 能 力 的 操作 , 即 称 为 超级 
链接 。 

超级 链接 格式 为 

<a href 一 "参数 1” target 一 "参数 2" title="BR 3">...</a> 


说 明 : 标签 二 a> 表 示 一 个 链接 的 开始 ,二 /a> 表 示 链 接 的 结束 ; 

href; 定义 了 这 个 链接 所 指 的 目标 地 址 ,目标 地 址 是 最 重要 的 ,一 旦 路 径 上 出 现 差 

title; 该 属性 用 于 指定 指向 链接 时 所 显示 的 标题 文字 ; 

target: 该 属性 用 于 指定 打开 链接 的 目标 窗口 ,其 默认 方式 是 原 窗口 。 该 属性 的 属性 
值 , 如 表 2-1 所 示 。 


表 2-1 target 的 属性 值 


属性 值 fi iB 
_parent 在 上 一 级 窗口 中 打开 ,一 般 使 用 分 帧 的 框架 页 会 经 常 使 用 
_blank 在 新 窗口 打开 
_self 在 同一 个 帧 或 窗口 中 打开 ,这 项 一 般 不 用 设置 
_top 在 浏览 器 的 整个 窗口 中 打开 ,忽略 任何 框架 
2. 链接 路 径 


标记 二 a 二 的 href 属性 可 以 接受 绝对 路 径 和 相对 路 径 。 可 以 通过 绝对 路 径 链接 站 点 
外 的 资源 ,如 二 a href="http://211. 81. 40. 73/dz/dtwz/index. asp " title="" target = 
" blank" >JSP 精品 课 网 站 二 /a 二 ; 也 可 以 通过 相对 路 径 链接 站 点 内 资源 ,如 二 a href= 
"ch2-6. html" title="" target="_blank" 二 基本 表格 例题 二 /a>。 


3. 发 送 E-mail 


在 HTML 页 面 中 ,可 以 建立 E-mail 链接 。 当 浏览 者 单 击 链接 后 ,系统 会 启动 默认 的 
本 地 邮件 服务 系统 发 送 邮件 。 
格式 为 


<a href="mailto: E-mali 地 址 : subject = BE f E" > ...</a> 

如 上 题 中 用 到 的 过 a href= "mailto; sungian_teacher@ 163. com" title=" " ></a>. 
4. 表格 标题 

设置 表格 标题 的 格式 为 

caption align 一 参数 > 一 /caption> 

其 中 参数 一 left center, right; 


<caption valign— Z% > </caption> 
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其 中 参数 二 top、bottom。 
注意 : <caption> E ZX 4E — table MAAN. ERRATA <tr> HAZ. <caption> 
标签 的 默认 属性 是 标题 位 于 表格 的 上 方 中 间 位 置 。 


本 章 小 结 


本 章 大 家 学 习 了 文本 标记 、 表 格 标记 、 链 接 标 记 、 图 片 标记 等 HTML 的 基础 知识 ,了 
解 网 页 的 基本 结构 是 我 们 顺利 进入 动态 网 站 开发 殿堂 的 基石 。 


本 章 习题 


【思考 题 】 在 基本 表格 中 设置 一 些 表格 属性 ,完成 如 图 2-6 所 示 的 页 面 效 果 。 


图 2-6 基本 表格 页 面 效果 


【学 习 目标 】 
1. 掌握 JSP 注释 ,JSP 指令 .脚本 元 素 及 JSP 动作 的 使 用 方法 。 
2. 能 够 根据 项 目 需 要 ,熟练 使 用 JSP 语法 进行 项 目 开 发 。 


【知识 结构 图 】 

[er] 
声明 
表达 式 

ri | <@page> 用 来 定义 整个 JSP 页 面 的 属性 和 属性 值 

法 指令 

á <@page> 用 于 在 JSP 页 面 中 静态 的 插入 一 个 被 包含 的 文件 

<jspiinclude> 在 页 面 被 请 求 时 动态 的 引入 一 个 文件 


[3spiparam> 用 于 参数 传递 ， 常 与 其 他 动作 配合 使 用 ， 不 能 单独 使 用 ) 


| taglib 、plugin 、useBean 、setProperty 、getProperty 等 动作 


3.1 JSP 注释 、 表 达 式 
实战 演练 全 JSP 页面 基本 结构 体验 


本 题目 主要 是 为 了 让 大 家 体验 JSP 页 面 的 基本 结构 ,以 及 两 种 注释 的 书写 方法 。 
JSP 页 面 可 以 由 7 种 元 素 组 成 ,分 别 是 : 普通 的 HTML 标记 、JSP 指令 标记 、JSP 动 
作 标记 、 变 量 声明 与 方法 声明 ,程序 片 .表达 式 .注释 。 
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本 题目 中 用 到 了 JSP 注释 和 HTML 注释 。 
【运行 效果 】 

在 开发 工具 MyEclipse 中 新 建 Web Project. 工程 名 称 命名 为 jsp-yufa( 如 图 3-1 所 
示 ) ,在 此 工程 中 的 WebRoot 文件 夹 下 新 建 工程 文件 ex4.jsp。 程 序 输入 完毕 并 且 保 存 之 
后 ,运行 开发 工具 MyEclipse 中 的 Tomcat 服务 器 (如 图 3-2 所 示 ) ,并 且 选 择 服务 器 需要 服 
务 的 工程 (如 图 3-3(a) 和 图 3-3(b) 所 示 )。 最 后 在 浏览 器 中 输入 地 址 http://127. 0. 0. 1: 
8080/jsp-yufa/ex4. jsp 就 可 以 看 到 运行 结果 了 (如 图 3-4 所 示 ) 。 


f? New Web Pro 


Create a Web Project 


Create a web project in the workspace or an erternal location 


Web Project Details 
Project Name jsp-yufd 
Location E Use default location 


Source folder src 
Web root folder WebRoot 
Context root URL |/jsp-yufa 


图 3-1 工程 名 称 为 jsp-yufa 


®MyEclipse Java Enterprise — MyEclipse Enterprise Yor... MOR 

Eile Edit Navigate Search Project MyEclipse Bun Window Help 

Lu * a 2223-9 eia- ig E ensi. 

*-0-Q- BHG- S78 

13 Package min SEo =o 
B An outline is 

; t 
* d Jep-chaz available, 
#13 jsp-nz 


SE? jsp-page 


WB Jone toi tity E Problem [Tasks © Console f Serversy. 9 Web Bro | 
i Root 2 055m ax 
218 jsp-zcdl Server Status Mode 
# MyEclipse Derby E Stopped 
A MyEclipse Tomcat tl Stopped 
= ATomat 5.x [default] Running O Run 
号 v OK © Exploded 
v 0K © Exploded 
vk © Exploded 
M © Exploded 
$ jsp-chaz v OK © Exploded 


Locatid 


图 3-2 3jzíT Tomcat 服务 器 
【 源 代码 】 
[ex4. jsp] 


<%@ page contentType= "text/html; charset—gb2312" language— "java" %> 
<html> 


1 

2 

3. <head> 
4 <title>JSP 页 面 结构 体验 一 /title> 
5 </head> 


ver Deployments 


Manage Deploynents 
Deploy and undeploy J2EE projects. 


Y 
Tyre Location ] Add 
Exploded D:\Program Files\Apache Software 
vB jsp-shop Exploded D:\Program Files\Apache Software 
(a) 


®New Deployment 


New Deployment =F 
Create new project deployment for Tomcat 5.x 


Server: Tomat 5.x 

Project: 4 
Edit server connectors... 

Deploy type: © Exploded Archive (development mode) OPackaxed Archive (production mode) 

Deploy Location: [ram Files\Apache Software Foundation\Toncat 5. 5\nebapps\jep-yufa 


(b) 


图 3-3 添加 需要 服务 的 工程 


Ug: - 360 安 全 浏览 器 4. .. (COR 
文件 E) HAV AB) HPU IAT) 帮助 H) 6 eR 
OFRO [X aO Qur- yet €) GIR- 
地 址 (D) E 127.0.0.1 | os 回访 问 
RER) oe 


图 3-4 ex4. jsp 


<body> 
<!-- 这 是 一 个 HTML 注释 ,下 面 是 一 个 方法 声明 ,add 方法 用 于 完成 加 法 运算 --> 
<%-- 这 是 一 个 JSP 注释 ,下 面 是 一 个 方法 声明 ,add 方法 用 于 完成 加 法 运算 --%> 
去 %%!// 声 明 add 方 法 , 带 和 两 个 inc 型 参数 进行 运算 ,返回 值 为 int 类 型 
public int add(int i, int j) 
{ 

int temp—0; 

for( ;i<=j;it++) 


{ temp+ =i; } 
return temp; 

) 

4 

<font size=5 color= # 0066cc> 
<p>JSP 页 面 结构 体验 ,本 页 面包 含 : 


<br/> &-nbsp; & nbsp; & nbsp; & nbsp; 
普通 的 HTML 标记 ;JSP 指令 标记 ;变量 声明 与 方法 声明 ;程序 片 ;表达 式 ;注释 。 
<% // 调 用 add 方法 ,传递 的 参数 为 1 和 5 


> [ 动态 网 站 设计 Si 人 一 sp] 000 


23 out. printin("<p> AF 1 到 5 的 和 是 : "十 add(1,5)); 

24 %> 

25 </font> 

26 </body> 

27 </html> 
【补充 说 明 】 

上 面 源 代码 中 第 1 行 是 ISP 指令 标记 ,以 二 %@ 开 头 ,以 % 二 结束 ; 第 2 行 到 第 6 行 
是 HTML 标记 ; 第 7,8 行 是 注释 ; 第 9 行 到 第 17 行 是 方法 声明 ,以 二 %! 开头 ,以 % 二 
结束 ; 第 22 行 到 第 24 行 是 Java 程序 片 ,以 二 % 开 头 , 以 % 二 结束 ; 第 22 行 ,以 // 开 头 的 
语句 是 Java 注释 。 


311 JP 页 面 结构 


JSP 页 面 由 7 种 元 素 组 成 。 

(1) 普通 的 HTML 标记 ,如 二 html >.< head >.< body 二 等 。 

(2) JSP 指令 标记 ,如 二 @ page >.< @ include 二 等 。 

(3) JSP 动作 标记 ,以 二 jsp: 开 头 ,以 /二 或 二 /jsp: 动 作 二 结束 的 标记 。 

(4) 变量 声明 与 方法 声明 (Declaration) : 在 程序 中 志 儿 和 铬 二 之 间 声 明 的 变量 只 在 
本 页 面 有 效 , 是 局 部 变量 ,在 不 同 的 客户 端 访 问 同 一 个 页 面 时 ,此 变量 不 能 共享 ; 但 如 果 
在 二 %! 和 % 志 之 间 声 明 变 量 就 可 以 在 不 同 页 面 共享 ,其 有 效 范围 是 整个 JSP 页 面 ,在 
服务 器 关闭 后 变量 才 会 被 释放 。 这 在 后 面 的 很 多 例题 中 都 将 体现 。 

(5) 程序 片 : 在 JSP rh. dE ACRI > Ze [8] 73 WY EARS RISO. Java 程序 片 ,一 个 
JSP 页 面 可 以 有 多 个 Java 程序 片 。 

(6) 表达 式 : 用 二 % 二 和 % 二 可 以 直接 输出 变量 或 表达 式 的 值 ,变量 或 表达 式 的 值 
将 作为 一 个 字符 串 在 浏览 器 中 输出 。 这 种 方法 在 JSP 编程 中 比较 常用 ,特别 在 Java 和 
HTML 标记 混合 编写 JSP 程序 中 是 较为 常用 的 。 

(7) 注释 ,包含 HTML 注释 和 JSP 注释 。 


312 注释 


适当 地 在 JSP 程序 中 加 入 注释 可 以 增加 程序 的 可 读 性 ,以 方便 维护 。 即 使 对 于 程序 
编写 人 员 ,注释 对 调试 和 编写 程序 也 可 起 到 良好 的 辅助 作用 。 程 序 员 在 程序 中 书写 注释 
是 一 种 良好 的 习惯 ,在 平时 的 学 习 和 实践 中 要 注意 培养 这 种 习惯 。 

ISP 文件 中 注释 可 分 为 两 种 : HTML 注释 和 ISP 注释 。 


1. HTML 注释 
在 符号 二 !-- 与 -之 之 间 的 是 HTML 注释 ,JSP 不 会 解释 HTML 注释 ,而 直接 把 它 


交 给 客户 端的 浏览 器 。 因 此 ,这 种 注释 在 浏览 器 中 直接 查看 原文 件 时 可 以 看 到 。 
其 格式 如 下 : 


二 !- -注释 内 容 - -> 


MMOL NN EU MD MEO [情境 三 “JSP 语法 基础 ] Ke y 


用 法 ,如 上 面 题目 中 用 到 的 : 
二 !-- 这 是 一 个 HTML 注释 ,下 面 是 一 个 方法 声明 ,add 方法 用 于 完成 加 法 运算 --> 


2. JSP 注释 


JSP 注释 的 方法 有 以 下 4 种。 格式 分 别 如 下 : 

(OD <- -注释 内 容 - -%> 

(2) / /注释 内 容 

G) / * 注释 内 容 */ 

(4) / xx 注释 内 容 */ 

第 一 种 注释 会 被 JSP 引擎 忽略 ,一 般 用 来 对 Java 程序 片 进行 说 明 。 如 上 面 题 目 中 用 
到 的 : 二 %-- 这 是 一 个 JSP 注释 ,下 面 是 一 个 方法 声明 ,add 方法 用 于 完成 加 法 运 
45-5. 

第 二 种 注释 是 单行 注释 ,如 上 面 题目 中 用 到 的 : // 调 用 add 方法 ,传递 的 参数 为 
1 和 5。 

第 三 种 方式 可 以 是 单行 注释 ,也 可 以 是 多 行 注释 。 

第 四 种 方式 是 Java 所 特有 的 doc 注释 。 

注释 在 编写 程序 和 调试 程序 中 特别 有 用 ,比如 在 调试 一 段 程序 中 的 几 行 程序 时 ,可 以 
注释 其 他 程序 ,这 样 JSP 引擎 就 不 会 编译 它 , 这 是 一 种 比较 常用 的 程序 调试 方法 。JSP 注 
释 是 不 会 在 浏览 器 中 通过 查看 源 文 件 的 方法 看 到 的 。 


实战 演练 2 一 字符 串 作 为 表达 式 输出 


(aA) 

题目 完成 的 功能 是 把 字符 串 “ 表 达 式 练习 ”. 作 为 表达 式 进行 输出 操作 。 
【分 析 】 

本 题目 是 对 表达 式 的 练习 ,程序 中 把 表达 式 放 入 一 个 for 循环 中 ,做 固定 次 数 的 输出 。 
【运行 效果 】 

打开 开发 工具 MyEclipse, 在 上 一 个 题目 所 建 [cs © 127001 » snis | ET o 
立 的 工程 jsp-yufa 中 的 WebRoot 文件 夹 下 ,新 建 HE) NAT. BEES - 


工程 文件 ex2.jsp。 程 序 输入 完毕 并 且 保存 之 后 ， E53 
运行 开发 工具 MyEclipse 中 的 Tomcat 服务 器 。 表达 式 练习 
达 式 练习 
最 后 在 浏览 器 中 输入 地 址 http://127. 0. 0. 1; ere 
SOBD Lisp: yufa/ex2 jsp 就 可 以 看 到 运行 结果 了 bien 
(如 图 3-5 所 示 ) 。 
【 源 代 码 】 图 3-5 表达 式 练习 的 运行 结果 
【ex2. jsp] 


1 <%@ page contentType="text/html; charset— gb2312" language— "java" % > 
2 <html> 


> [动态 网 站 设计 Ss 制 人 一 J55] 7 t 


3 <head> 
4 <title> IKK AA </title> 
5 </head> 
6 <body> 
7 <center> 
8 <font color= #006600 size=5> 
9 <% 
10 String s 一 "表达 式 练习 "; 
11 int i=0; 
12 for(;i<=6;i++) 
13 { 
14 %> 
15 <%=s %> 
16 <% 
17 out. println("< br>"); 
18 } 
19 n2 
20 </font> 
21 </center> 
22 </body> 
23 </html> 
【补充 说 明 】 


第 7 行 是 为 了 把 输出 的 文本 居中 显示 ; 第 8 行 是 设置 输出 的 文本 字号 和 颜色 ; 第 9 行 
到 第 19 行 是 两 段 程序 片 和 一 个 表达 式 , 使 用 for 循环 把 字符 串 s 作为 表达 式 做 循环 输出 。 


313 表达 式 
JSP 表达 式 的 语法 格式 如 下 : 
二 % 一 表达 式 %> 


d — N = AM > bri H i E Java 表达 式 , 可 以 直接 输出 Java 表达 式 的 值 。 例 如 
上 面 题目 中 的 用 法 : -— s 名 过。 表达 式 的 值 由 服务 器 负责 计算 ,并 将 计算 值 转换 成 字 
符 串 发 送 给 客户 端 显示 。 表 达 式 在 ISP 编程 中 较 常 用 ,特别 是 在 与 HTML 标记 混合 编 
写 时 使 用 较 多 。 


3.2 JSP 的 变量 声明 .方法 声明 


实战 演练 全 一 判断 并 计算 三 角形 面积 


【题目 】 

在 界面 的 三 个 文本 框 中 输入 数字 作为 三 角形 的 三 个 边 ,然后 提交 这 三 个 数字 。 如 果 
这 三 个 数字 能 构成 三 角形 , 则 计算 三 角形 的 面积 ; 如 果 不 能 构成 三 角形 , 则 输出 文字 “不 
能 构成 三 角形 ”。 在 显示 计算 结果 的 时 候 要 显示 刚刚 输入 过 的 三 个 数字 。 最 后 ,要 有 一 个 
“返回 ”的 链接 ,能 够 回 到 输入 界面 。 


【分 析 】 

本 题目 以 判断 三 角形 和 计算 三 角形 的 面积 为 例 ,向 大 家 介绍 JSP 脚本 和 声明 的 用 
法 。 代 码 中 使 用 了 二 %! 和 % 志 标记 声明 变量 。 这 是 一 个 让 大 家 熟悉 ISP 程序 书写 方 
法 的 过 渡 阶 段 。 
【运行 效果 】 

打开 开发 工具 MyEclipse, 在 工程 jsp-yufa 中 的 WebRoot 文件 夹 下 ,新 建 工程 文件 
exl l.jsp 和 exl_2. jsp。 程 序 输 入 完毕 并 且 保 存 之 后 ,运行 开发 工具 MyEclipse 中 的 
Tomcat 服务 器 。 在 浏览 器 中 输入 地 址 http://127. 0. 0. 1:8080/jsp-yufa/exl_1. jsp. 

(1) 首先 运行 的 是 exl 1.jsp 页 面 ,效果 如 图 3-6 所 示 。 在 文本 框 中 分 别 输入 三 个 数 
字 , 然 后 单 击 “ 计 算 ” 按 钮 ,页面 把 已 输入 的 三 个 数值 提交 到 ex1_2. jsp 页 面 。 

(2) exl_2.jsp 页 面 运行 效果 如 图 3-7 所 示 , 显 示 了 上 一 页 面 输入 的 三 个 数值 ,并 且 
显示 运算 结果 ,另外 还 有 “返回 "链接 可 以 回 到 上 一 个 页 面 继续 操作 。 


OSPR. 声明 = 
请 输入 三 角形 三 个 边 的 长 度 


[ = 


日 皮肤 > OF duke oaa (*) OT ume aq- 


图 3-6 exl 1.jsp 页 面 图 3-7 exl 2.jsp RA 


【 源 代码 】 
【exl_1.jsp】 本 页 面 的 设计 中 使 用 了 一 个 表单 ,表单 中 放置 了 三 个 文本 框 , 名 称 分 别 为 
a.b、c, 还 有 一 个 提交 按钮 。 


1 <%@ page contentType="text/ HTML; charset=gb2312" language= "java" %> 
2 <HTML> 

3 <head> 

4 <title>JSP 脚本 , 5 Bj — /title 

5 </head> 

6 <body bgcolor=" # FFFFCC"> 

7 <center> 

8 <font color=" £ 946714" size="3"> 

9 <p> iii A —f5E— TWN KE: </p> 


10 <form action—"exl 2.jsp" method="post" name="form" > 
11 <input type="text" name— "a" size="5"/> 

12 <input type="text" name="b" size="5"/> 

13 <input type="text" name="c" size="5"/> 

14 <input type="submit" value— "iT $E" name— "submit" /> 


15 </form> 
16 </center> 
17 </body> 
18 </HTML> 
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[ex1 2. jsp] 


1 <%@ page contentType— "text/ HTML; charset—gb2312" language— "java" % > 
2 <HTML> 

3 <head> 

4 <title>JSP 脚本 .声明 一 /title> 

5 </head> 

6 <body bgcolor=" # FFFFCC"> 

7 

8 

9 


<center> 

<font color=" £ 946714" size= "3"> 

x»! 
10 double s—0; 
11 String answer— null; 
12 6n 
13 <% 
14 double a= Double. parseDouble( request. getParameter("a")) ; 
15 double b= Double. parseDouble( request. getParameter("b")) ; 
16 double c= Double. parseDouble( request. getParameter("c") ) ; 
17 if((atb>c)&.& (b+ce>a)&&(ate>b)) 
18 ( 
19 double p=(a+b+c)/2; 
20 s= Math. sqrt(p * (p-a) * (p-b) * (p-c)); 
21 out. print" MAE: "+s); 
22 ) 
23 else 
24 ( 
25 answer 一 "您 输入 的 三 边 不 能 构成 一 个 三 角形 "; 
26 out. print("<br>"-++answer) ; 
27 ) 
28 5n 


29 <p> Shi A HY = 2 : 

30 <% =a% > &nbsp; & nbsp; &-nbsp; < % =b% > & nbsp; &-nbsp; &-nbsp; <% =c% ></p> 
31 <a href—"exl 1.jsp" target="_self">i& </a> 

32 </center> 

33 </body> 

34 </HTML> 


【补充 说 明了】 
exl 1.jsp 代码 说 明 

第 10 行 到 第 15 行 是 一 个 表单 ,以 二 form 二 开始 ,以 一 /form 之 结束 ,表单 中 有 三 个 文 
本 框 ,文本 框 的 名 字 分 别 为 a、b、c, 还 有 一 个 提交 按钮 .按钮 上 的 文本 为 “计算 ”, 当 单 击 
“计算 ”按钮 之 后 ,文本 框 中 的 数据 提交 到 ex1_2. jsp 页 面 。 
ex1_2. jsp 代码 说 明 

第 9 行 到 第 12 行 是 变量 声明 ,以 二 %! OF DL — Wo £89.08 13 行 到 第 28 行 
是 Java 程序 片 ; 第 14 到 第 16 行 是 接收 表单 exl_1. jsp 页 面 传递 过 来 的 数据 a,b,c, 34H. 
把 数据 转换 成 为 double 类 型 ; 第 17 行 到 第 27 行 是 一 个 条 件 语 句 , 用 来 判断 这 三 个 数值 
能 否 构 成 三 角形 ,如 果 能 构成 三 角形 . 则 计算 三 角形 的 面积 ,如 果 不 能 构成 三 角形 , 则 显示 


文字 “您 输入 的 三 边 不 能 构成 一 个 三 角形 ”; 第 30 行 把 三 个 变量 做 了 表达 式 的 输出 ; 第 
31 行 设置 了 一 个 “返回 ”链接 ,可 以 返回 到 exl_1.jsp 页 面 ,继续 操作 。 


321 使 用 声明 
变量 和 方法 在 过 外 ! 和 名 之 标记 之 间 声 明 , 声 明 变 量 和 方法 的 语法 和 格式 同 Java 


语 


bii 


语法 格式 如 下 : 
二 %! 声 明 1;[ 声 明 25]. 962 
例如 上 面 题目 中 用 到 的 : 


<%! 
double s=0; 
String answer= null; 
%> 
声明 变量 : 就 是 在 二 %! 和 % 二 标记 之 间 放 置 Java 的 变量 声明 语句 。 变 量 的 数据 类 
型 可 以 是 Java 的 任何 数据 类 型 。 
声明 方法 : 声明 的 方法 在 整个 页 面 内 有 效 , 称 为 页 面 的 成 员 方 法 。 
方法 内 声明 的 变量 称 为 局 部 变量 ,只 在 方法 内 有 效 ,方法 调用 为 其 分 配 空间 ,调用 完 
毕 后 释放 变量 空间 ; 全 局 变量 在 所 有 客户 之 间 该 页 面 有 效 。 
在 程序 中 二 % 和 % 二 之 间 声 明 的 变量 只 在 本 页 面 有 效 , 是 局 部 变量 ,在 不 同 的 客户 端 
访问 同一 个 页 面 时 ,此 变量 不 能 共享 。 但 如 果 在 二 %! 和 % 志 之 间 声 明 的 变量 就 可 以 在 
不 同 页 面 共享 ,其 有 效 范围 是 整个 JSP 页 面 ,在 服务 器 关闭 后 变量 才 会 被 释放 。 


322 表单 的 设计 


在 上 面 题目 中 首次 用 到 了 表单 ,表单 在 Web 网 页 中 用 来 给 访问 者 填写 信息 ,从 而 能 
采集 客户 端 信息 ,使 网 页 具有 交互 的 功能 。 一 般 是 将 表单 设计 在 一 个 HTML 文档 中 , 当 
用 户 填 写 完 信息 后 做 提交 (submit) 操 作 , 于 是 表单 的 内 容 就 从 客户 端的 浏览 器 传送 到 服 
务 器 上 ,经 过 服务 器 处 理 程序 处 理 后 ,再 将 用 户 所 需 信 息 传送 回 客户 端的 浏览 器 上 ,这 样 
网 页 就 具有 了 交互 性 。 下 面 详细 了 解 一 下 表单 在 ISP 中 如 何 使 用 。 


1. 表单 标记 


一 个 表单 用 过 form> 二 /form 之 标志 来 创建 。 也 即 定义 表单 的 开始 和 结束 位 置 ,在 
开始 和 结束 标志 之 间 的 一 切 定 义 都 属于 表单 的 内 容 。 所 form 之 标志 具有 action, method 
和 target 属性 。 

(1) action 的 值 是 处 理 程序 的 程序 名 (包括 网 络 路 径 、 网 址 或 相对 路 径 ), 如 二 form 
action 一 "exl_2. jsp" method="post" name="form">. 

如 果 这 个 属性 是 空 值 ,如 二 form action=" " method="post" name="form"> 

则 当前 文档 的 url 将 被 使 用 。 当 用 户 提 交 表 单 时 ,服务 器 将 执行 当前 文档 里 面 的 
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程序 。 

(2) method 属性 用 来 定义 处 理 程 序 从 表单 中 获得 信息 的 方式 ,可 取 值 为 GET 和 
POST 中 的 一 个 。GET 方式 是 处 理 程序 从 当前 HTML 文档 中 获取 数据 ,然而 这 种 方式 
传送 的 数据 量 是 有 限制 的 ,一 般 限制 在 IKB(255 个 字 节 ) 以 下 。POST 方式 传送 的 数据 
比较 大 , 它 是 当前 的 HTML 文档 把 数据 传送 给 处 理 程序 ,传送 的 数据 量 要 比 使 用 GET 
方式 传送 的 数据 量 大 得 多 。 

在 JSP 中 ,服务 器 端 程序 与 客户 端 交互 最 常用 的 方法 就 是 采用 表单 提交 数据 。 表 单 
提交 的 方法 主要 有 两 种 ,一 种 是 get 方法 ; 另 一 种 是 post 方法 。 两 者 最 大 的 区 别 是 : 使 
get 方法 提供 的 数据 会 显示 在 浏览 器 的 地 址 栏 中 ; 而 使 用 post 方法 则 不 会 显示 , 故 
post 更 为 常用 。 

(3) target 属性 用 来 指定 目标 窗口 或 目标 帧 。 


Sm 


2. input ib 


在 HTML 语言 中 ,标记 迄 input 之 具有 重要 的 地 位 , 它 能 够 将 浏览 器 中 的 控件 加 载 到 
HTML 文档 中 ,该 标记 是 单个 标记 ,没有 结束 标记 。 
写 人 标记 格式 如 下 : 


<input type 一 参数 name= FR... > 
例题 中 的 用 法 : 


<input type="text" name="c" size="5"/> 

<input type="submit" value— "1 3E" name= "submit" /> 

Type 属性 : 指定 控件 的 类 型 , 取 值 为 text, radio, checkbox, password, hidden, 
submit,reset 等 。 

Name 属性 : 指定 空间 对 象 名 称 ,通过 该 属性 ,使 用 request. getParameter 方法 获得 
用 户 提交 的 数据 。 

定义 一 个 用 户 输入 区 ,用户 可 在 其 中 输入 信息 。 此 标志 必须 放 在 二 form 之 二 /form> 
PREX ZE. <input type=" ">R E PIET 9 种 类 型 的 输入 区 域 ,本 例题 中 用 到 的 
是 文本 输入 区 和 提交 按钮 。 


实战 演练 2 一 计算 圆 面积 和 周 长 


【题目 】 
界面 上 有 一 个 文本 框 ,输入 圆 的 半径 ,然后 单 击 “ 计 算 ” 按 钮 ,在 本 页 面 得 出 计算 的 面 
积 和 周 长 。 
【分 析 】 
CL) 本 题 使 用 了 一 个 Circle 类 ,类 中 有 计算 面积 的 方法 有 计算 周 长 的 方法 有 Circle 
对 象 的 初始 化 。 题 目 是 通过 创建 Circle 类 的 对 象 ,用 对 象 调用 类 的 方法 来 完成 运算 的 。 
(2) 页 面 中 需要 有 一 个 表单 ,表单 中 包括 一 个 文本 框 和 一 个 提交 按钮 。 
G) 因为 题目 只 用 一 个 页 面 完成 ,所 以 表单 提交 到 本 页 面 进行 运算 , 当 页 面 第 一 次 被 
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加 载 的 时 候 , 给 半径 赋值 为 1”; 当 页 面 不 是 首次 Pee EACE 
加 载 的 时 候 , 把 表单 提交 的 半径 用 于 后 面 的 运算 。 BRATS, BEER 
【运行 效果 】 

在 工程 jsp-yufa 中 的 WebRoot 文件 夹 下 ,新 
建 工程 文件 ex5. jsp。 程 序 输 入 完毕 并 且 保 存 之 
后 ,运行 开发 工具 MyEclipse 中 的 Tomcat 服务 
器 。 在 浏览 器 中 输入 地 址 http://127. 0. 0. 1: 
8080/jsp-yufa/ex5. jsp 就 可 以 看 到 运行 结果 了 
(如 图 3-8 所 示 ) 。 
【 源 代码 】 
ex5. jsp] 


图 3-8 exs.jsp 页 面 


1 <%@ page contentType="text/html; charset=gb2312" language— "java" % > 
2 <%! public class Circle 
{ 


w 


4 double r; 

5 Circle(double r) 

6 {this.r=r; } 

7 // 面 积 

8 double mianji() 

9 ( return Math.PI*r*r; } 


10 // 周 长 

11 double zhouchang() 

12 { return Math.PI*2*r; ) 

13: } 

14 A 

15 <html> 

16 <head><title> 7r 1&8 AAA </title> 

17 </head> 

18 <body> 

19 <font color= # 00aaww size=4> 

20 <p> ii ii A AER ; 

21 <br> 

22 <form action="" method= post name= form 
23 <input type="text" name="R" vale="1"> 
24 <input type="submit" value="it#" name=submit> 
25 </form> 

26 <% 

27 String R= request. getParameter("R") ; 

28 double r; 

29 ifCR! — null) 

30 {r= Double. parseDouble(R) ; } 

31 else 

32 {r=1;} 


33 Circle circle=new Circle(r) ; // 创 建 对 象 
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34 %> 

35 xp Bag: 

36 <br> 

37 <%=r%> 

38 <p> AKARE: 

39 <br> 

40 <%=circle. mianji() %> 

41 <p> Wl AY Jed Ke = 

42 <br> 

43 <%=circle.zhouchang() %> 


44 </font> 
45 </body> 
46 </html> 


【补充 说 明 】 

第 2 行 到 第 14 行 是 公共 类 Circle 的 声明 ,里面 包含 了 构造 方法 ,用 于 完成 Circle 对 
象 的 初始 化 ,有 计算 面积 的 方法 mianji() ,有 计算 周 长 的 方法 zhouchang(); 第 22 行 到 第 
25 行 是 form 表单 ,表单 中 有 一 个 文本 框 , 变 量 名 为 人 ,可 以 输入 圆 的 半径 ,初始 值 设 为 1， 
有 一 个 提交 按钮 ,按钮 上 的 文字 设置 为 计算 ; 第 26 行 到 第 34 行 是 Java 程序 片 ,这 一 段 中 
第 27 行 完 成 的 是 接收 数据 ,第 29 到 第 32 行 的 if 条 件 语句 是 用 于 判断 页 面 是 否 第 一 次 加 
载 , 如 果 是 第 一 次 加 载 就 为 圆 的 半径 r 赋值 为 1, 如 果 不 是 第 一 次 加 载 就 做 数据 类 型 转 
换 ; 第 33 行 是 创建 一 个 Circle 类 的 对 象 circle, 并 且 用 r 的 值 为 这 个 circle 对 象 做 初始 化 
赋值 ; 第 37 47 40 FF 43 行 都 是 表达 式 的 输出 ,其 中 第 40 行 和 第 43 行 是 使 用 circle 对 象 
调用 了 计算 面积 和 周 长 的 方法 得 到 输出 值 的 。 


实战 演练 3 一 一 可 累计 的 投票 


【题目 】 

统计 候选 人 被 投票 的 数目 。 
【分 析 】 

CD 假设 有 三 个 候选 人 ,在 界面 上 放置 一 个 表单 ,其 中 包括 3 个 单 选 按钮 ,3 个 候选 人 
分 别 使 用 不 同 的 标识 ; 一 个 提交 按钮 ,用 于 投递 选票 。 

(2) 当选 票 提交 以 后 ,通过 候选 人 标识 进行 比较 ,是 谁 的 选票 就 给 谁 累计 票数 。 

(3) 定义 一 个 页 面 级 数组 变量 sum ,每 个 数组 元 素 表示 1 个 候选 人 。 

(4) 用 Synchronized 来 解决 多 个 线程 同时 访问 同一 个 共享 变量 的 问题 , 当 一 个 用 户 
Synchronized 操作 一 个 共享 变量 时 ,其 他 线程 就 必须 等 待 , 直 到 该 线程 执行 完成 。 
【运行 效果 】 

在 工程 jsp-yufa 中 的 WebRoot 文件 夹 下 .新建 工程 文件 ex7.jsp 和 ex7_1. jsp。 程 序 
输入 完毕 并 且 保 存 之 后 ,运行 开发 工具 MyEclipse 中 的 Tomcat 服务 器 。 在 浏览 器 中 输 
入 地 址 http; //127. 0. 0. 1: 8080/jsp-yufa/ex7. jsp 就 可 以 看 到 运行 结果 了 (如 图 3-9 和 
图 3-10 所 示 )。 


m 


图 3-9 ex7.jsp 投票 界面 图 3-10 ex7_1.jsp 投票 结果 


【 源 代码 】 
【ex7. jsp] 
1 <%@ page contentType="text/html; charset=gb2312" language="java" %> 
2 <html> 
3 <head> 
4 <<title> 表 单 练习 -- 选 举 一 /title> 
5 </head> 
6 <body> 
7 <form method="post" action="ex7_1.jsp"> 
8 <center> 
9 <font color= # ffggkk size— 67 3&2 — / font 
10 <hr color=" # ffggkk" size="2" width="60%"></hr> 
11 <font color= #996611 size=4> 
12 <p> 
13 <input type="radio" value="A" name— "num" /二 候选 人 A<br /> 
14 <input type="radio" valu nami num" /二 候选 人 B<br /二 
15 <input type="radio" value="C" name="num" /二 候选 人 C<br /><br /> 
16 <input type="submit" value= "t 9i" name— "tou" /> 
17 </font> 
18 </center> 
19 </form> 
20 </body> 
21 </html> 
[ex7 1. jsp] 
1 <%@ page contentType— "text/html; charset— gb2312" language— "java" %> 
2 <html> 
3 <head> 
4 <title> #4 R</title> 
5 </head> 
6 <body> 
7 <center> 
8 <% int sum[ ] =new int[3]; %> 
9 <% 
10 String num= request. getParameter( " num") ; 
11 synchronized( sum) 
12 { 
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13 if(num! = null) 
14 { 
15 if(num. compareTo(" A") = —0) 
16 sum[0] ++; 
17 if(num. compareTo("B") — —0) 
18 sum[{1]++; 
19 if(num. compareTo("C") = —0) 
20 sum[2] ++; 
21 } 
22 } 
23 %> 
24 <font color= # ffggkk size 一 6 二 选举 结果 一 br /></font> 
25 <hr color=" # ffggkk" size="2" width= "60% "></hr> 
26 <font color= # 996611 size=4> 
27 候选 人 A: <%=sum[0] %><br /> 
28 候选 人 B: <%=sum[1] % ><br /> 
29 候选 人 C: <%=sum[2] % ><br /><br /> 
30 </font> 
31 </center> 
32 </body> 
33 </html> 
【补充 说 明 】 
ex7.jsp 代码 说 明 


第 7 行 到 第 19 行 是 一 个 form 表单 ,设置 了 表单 数据 会 传递 给 ex7_1. jsp 代码 页 ; 第 
13 行 到 15 行 放置 了 三 个 单 选 按 钮 ,它们 的 标识 分 别 为 A、B、C, 名 字 都 用 num; 第 16 行 
放置 了 一 个 提交 按钮 ,按钮 上 文字 设置 为 投票 ,按钮 的 变量 名 为 tou。 
ex7_1.jsp 代码 说 明 

第 8 行 声明 了 一 个 数组 ; 第 9 行 到 第 23 行 是 程序 片 ; 第 10 行 是 接收 ex7.jsp 页 面 中 
表单 传递 过 来 的 单 选 按钮 的 变量 值 ; 第 11 行 到 第 22 行 是 用 Synchronized 来 定义 数组 
sum, 这 样 就 可 以 避免 多 个 用 户 同时 投票 时 产生 的 混乱 ,只 要 Tomcat 服务 器 不 重启 ,多 次 
打开 TE 调用 这 个 JSP 页面, 可 以 观察 到 sum 数组 可 以 完成 连续 统计 投票 结果 ; 第 13 行 
到 第 21 行 是 根据 num 的 标识 来 判断 给 哪 位 候选 人 累计 票数 ; 第 27 到 第 29 行 是 表达 式 
输出 ,输出 三 个 候选 人 的 票数 。 


3.3 JSP 指 令 


实战 演练 全 一 使 用 JP 指令 显示 当前 时 间 


【题目 】 
用 不 同 的 输出 方式 显示 当前 时 间 。 
【分 析 】 


本 题目 主要 是 让 大 家 体会 include 指令 的 用 法 。 这 个 示例 由 两 个 页 面 来 完成 ,使 用 


include 指令 来 读 人 能 够 显示 当前 的 日 期 和 时 间 的 页 面 。 
【运行 效果 】 

打开 开发 工具 MyEclipse. 在 上 一 个 题目 所 建 
立 的 工程 jsp-yufa 中 的 WebRoot 文件 夹 下 ,新 建 工 
程 文件 qj. time. jsp 和 dateshow. jsp。 程 序 输 入 完 
毕 并 且 保 存 之 后 ,运行 开发 工具 MyEclipse 中 的 | 201-12-21 11:28:58 
Tomcat 服务 器 。 最 后 在 浏览 器 中 输入 地 址 | 从 dateshom.jsp 页 面 回 未 7!! 
http://127. 0. 0. 1,8080/jsp-yufa/qj_time. jsp 就 图 3-11 运行 dj time. jsp 页 面 显示 
可 以 看 到 运行 结果 了 (如 图 3-11 所 示 ) 。 当前 时 间 
【 源 代码 】 
[aj time. jsp] 


1 <%@page language— "java" contentType— "text/ HTML ;charset—gb2312" %> 
2 <%@page import— "java. util. * "2677 
3 <HTML> 

4 <head> 

5 <title> include 3c ff] — / title 
6 </head> 

T <body bgcolor=" # FFFFCC"> 

8 <font color=" #946714" size="3"> 当 JSP 文件 遇 到 include 指令 时 会 读 人 其 指定 的 文件 : 
9 <%@ include file="dateshow. jsp" %> 

10 </font> 

11 <p> dateshow.jsp 页 面 回来 了 !! 

12 </body> 

13 </HTML> 


[dateshow. jsp] 


<% @page language "java" contentType— "text/ HTML ;charset— gb2312" 96 > 
— (3 page import— "java. util. * "%> 
<% 
// 变 量 today 被 声明 为 Date 类 型 ,可 以 得 到 时 间 信 息 
Date today 一 new Date() ; 
%> 
二 p 记 今天 的 日 期 是 二 %==today.getMonth() 十 1 %>H<%=today.getDate(.) 9675, 星期 
<%=today. getDay() %>, HY [B] Æ<% = today. getHours() % ><% = today. getMinutes() 
W^. 
8 <p><%=today. toLocaleString() 9677 


【补充 说 明了 
qj_time. jsp 代码 说 明 

第 2 行 是 使 用 page 指令 的 import 属性 引入 了 Java 的 util TRE ,在 这 个 包 中 ,Java 
提供 了 一 些 实用 的 方法 和 数据 结构 。 例 如 ,Java 提供 日 期 (Date) 类 H Jj (Calendar) BK 
产生 和 获取 日 期 及 时 间 ,因为 我 们 这 个 题目 中 用 到 了 Data 类 ,所 以 要 引入 这 个 工具 包 。 
第 9 行 是 使 用 include 指令 读 入 dateshow. jsp 页 面 的 代码 执行 完 dateshow. jsp 页 面 的 代 


oo 


Q (asmenis weise] 0 00 


15 2 Je x3 AAS RET Js TE). AAAH include 语句 的 位 置 。 
dateshow. jsp 代码 说 明 

第 2 行 是 使 用 page 指令 的 import 属性 引入 了 Java 的 util TA; 第 5 行使 用 到 了 
Date 类 ,通过 声明 Date 类 的 对 象 today 来 引用 一 些 方法 获取 当前 的 日 期 和 时 间 ; 第 7 行 
到 第 8 行 是 使 用 today 对 象 调用 Date 类 的 方法 来 实现 时 间 日 期 的 表达 式 输出 。 

在 这 个 例题 中 , dateshow. jsp 页 面 属 于 被 包含 的 文件 ,被 包含 的 文件 中 不 能 含有 
<HTML> 一/HTML>、 二 body> 或 一 /body 之 标签。 因为 被 包含 的 文件 的 全 部 内 容 
将 被 插入 JSP 文件 中 include 指令 所 在 的 地 方 , 这 些 标签 将 会 同 ISP 文件 中 已 有 的 同样 
的 标签 发 生 冲突 。 


331 page 指令 


page 指令 的 作用 范围 是 整个 JSP 文件 和 该 JSP 文件 用 include 48 42% <jsp:include> 
包含 进来 的 任何 静态 文件 ,整个 JSP 文件 和 这 些 静 态 文件 一 起 称 为 一 个 “平移 单元 ”。 
page 指令 不 适用 于 任何 动态 的 包含 文件 。 可 以 在 一 个 “平移 单元 "使 用 多 个 page 指令 ， 
但 是 每 一 个 属性 只 能 使 用 一 次 ,除了 import( 因 为 import 属性 和 Java 程序 语言 的 import 
语句 很 类 似 , 能 够 多 次 使 用 ,就 像 在 Java 语言 中 能 够 多 次 使 用 import 命令 一 样 ) Aie 
用 户 将 page 指令 放 到 JSP 文件 或 被 包含 的 文件 的 任何 一 个 位 置 , 它 的 作用 范围 都 是 整个 
“平移 单元 ”。 然 而 ,一 个 好 的 编程 风格 是 常常 将 它 放 到 文件 的 顶部 。 

例如 上 面 题目 中 用 到 的 语句 : 


<%@page language= "java" contentType— "text/ HTML; charset=gb2312" %> 
<%@page import— "java. util. * "% > 


这 其 中 用 到 的 属性 有 以 下 三 种 。 

1. language 属性 

language 一 "java" 表 示 在 JSP 文件 的 脚本 段 .声明 和 表达 式 中 使 用 的 语言 。 
2. contentType 属性 


该 属性 用 来 设置 JSP 页 面 的 MIME type 和 character encoding( 字 符 编码 ) ,用 于 响 
应 客户 端的 请 求 。contentType 二 "text/HTML;charset = gb2312" 表 示 设 置 的 MIME 
type 是 text/ HTML ,字符 编码 集 是 gb2312 。 


3. import 属性 


该 属性 用 来 导入 页 面 中 要 用 到 的 包 或 类 ,导入 的 包 或 类 可 以 是 Java 环境 的 核心 类 ， 
也 可 以 是 用 户 自己 编写 的 包 或 类 。 用 法 为 : <%@page import= "java. util. «"%> JSP 
文件 中 可 以 导入 一 个 或 多 个 用 逗号 隔 开 的 包 或 类 ,例如 : 


<%@ page import 一 "java.io. * ", "java. util. * ", "java. sql. * " %> 


默认 情况 下 ,JSP 页 面 import 属性 有 以 下 值 : 


情境 三 J5P 语 法 基础 > 
java. lang. * ,javax. servlet. * ,javax. servlet. jsp. * ,javax. servlet. http. * 。 
332 include 指 令 


include 指令 可 以 在 JSP 文件 中 插入 一 个 包含 文本 和 代码 的 文件 。 被 包含 的 文件 可 
以 是 JSP X fF. HTML 文件 或 文本 文件 。 


语法 格式 如 下 : 
<% G include file= "relativeURL" % > 
上 面 例题 中 的 用 法 如 下 : 


<%@ include file="dateshow. jsp" %> 


如 果 被 包含 的 文件 是 JSP 文件 , 则 JSP 引擎 编译 完 该 ISP 文件 后 ,执行 的 结果 将 搬 
和 到 主 JSP 文件 中 include 指令 所 在 的 位 置 ; 如 果 被 包含 的 文件 是 HTML 文件 或 文本 文 
件 , 则 JSP 引擎 不 对 其 进行 编译 ,直接 将 其 内 容 插 入 主 JSP 文件 中 include 指令 所 在 的 
位 置 。 

该 包含 是 静态 包含 , 即 被 包含 的 文件 处 理 完 ,而 且 结果 也 插入 主 JSP 文件 完毕 后 , 主 
JSP 文件 将 继续 执行 include 指令 下 面 的 内 容 。 

注意 : 

(1) RD LH PH SA <html>, </html>, <body> S </body>. A 
为 被 包含 的 文件 的 全 部 内 容 将 被 插入 JSP 文件 中 include 指令 所 在 的 地 方 , 这 些 标签 将 会 
同 JSP 文件 中 已 有 的 同样 的 标签 发 生 冲 突 。 

(2) 假如 被 包含 的 文件 发 生变 化 , 主 JSP 页 面 将 被 重新 编译 。 


333 Date 对 象 


Date 对 象 是 一 个 有 关 日 期 和 时 间 的 对 象 。 它 具有 动态 性 , 即 必须 使 用 new 运算 符 创 
建 一 个 实例 。 例 如 


Date today=new Date() ; 
Date 对 象 没有 提供 直接 访问 的 属性 ,只 具有 获取 和 设置 日 期 和 时 间 的 属性 。 
实战 演练 2 一 include 指令 练习 


【题目 】 

需要 完成 的 功能 是 链接 前 面 的 任意 三 个 例题 ,本 题 以 链接 JSP 页 面 结构 体验 、 表 达 
式 练习 、 方 法 声明 练习 为 例 。 
【分 析 】 

本 题 使 用 include 指令 调和 head. jsp, body. jsp ,foot. jsp 三 个 文件 来 完成 ex6. jsp 的 
页 面 功 能 显示 。 
【运行 效果 】 

打开 开发 工具 MyEclipse, 在 工程 jsp-yufa 中 的 WebRoot 文件 夹 下 ,新 建 工程 文件 
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ex6. jsp, head. jsp, body. jsp, foot. jsp。 程 序 输入 完毕 并 且 保 存 之 后 ,运行 开发 工具 
MyEclipse 中 的 Tomcat 服务 器 。 在 浏览 器 中 输入 地 址 http://127. 0. 0. 1: 8080/ 
jsp-yufa/ex6. jsp 就 可 以 看 到 运行 结果 了 (如 图 3-12 所 示 ) 。 


includef}#4 


1、JSP 页 面 结构 体验 


今天 的 日 期 是 : 2012-3-1 11:09:40 3 


图 3-12. ex6. jsp 


【 源 代码 】 

【ex6. jsp] 
1 <%@page language="java" contentType="text/html;charset=gb2312" import="java. util. * "%> 
2 <html> 
3 <center> 
4 <%@ include file— "head. jsp" %> 
5 <%@ include file="body.jsp"% > 
6 <%@ include file="foot.jsp" %> 
7 </center> 
8 </html> 

[head. jsp] 


1 <%@page language="java" contentType = "text/html ;charset—gb2312" import— "java. util. * "967 
2 <font color= # 00ccaa size="6"> include # 4 3 ff] </font> 


[body. jsp] 
1 <%@page contentType= "text/html ;charset— gb2312" import="java. util. x "% > 
2 <hr size="2" width— "6026" color=" # 00ccaa" 
3 <p><a href="ex4.jsp">1 JSP 页 面 结构 体验 一 /a> 
4 <p><a href="ex2.jsp">2,#iARAY </a> 
5 <p><a href="ex5.jsp">3. WwW AY </a> 
6 <hr size="2" width="60%" color=" # 00ccaa"> 
foot. jsp] 
1 <%@page contentType— "text/html; charset=gb2312" import="java. util. x "% > 
2 <% 
3 —//HÉf today 被 声明 为 Date 类 型 ,可 以 得 到 时 间 信 息 
4 Date today=new Date() ; 
5 %> 
6 <p>SAW AE: 
7 <%=today. toLocaleString() %> 


情境 三 15P 语 法 基础 


【补充 说 明 】 
ex6. jsp 代码 说 明 

第 1 行 是 page 指令 ,其 中 import 属性 引入 了 util 工具 包 , 因 为 后 面 会 用 到 日 期 类 ， 
第 4 行 到 第 6 行 都 是 include 指令 的 语句 .分 别 引 入 了 head. jsp, body. jsp, foot. jsp 三 个 
文件 来 完成 ex6.j jsp 的 页 面 功能 显示 。 


head. jsp 代码 说 明 

第 2 行 代码 用 于 设 定 指定 文字 的 格式 。 
body. jsp 代码 说 明 

第 2 行 和 第 6 行使 页 面 插入 了 彩色 的 水 平 线 ; 第 3 行 到 第 5 行 设置 了 三 个 链接 。 
foot. jsp 代码 说 明 


第 4 行 新 建 了 一 个 Date 类 的 对 象 today; 第 7 行 用 于 把 当前 时 间 以 表达 式 的 形式 输出 。 


3.4 taglib 指令 


实战 演练 一 一 taglib 指 令 引 入 页 脚 的 练习 


【题目 】 

使 用 taglib 指令 完成 版 权 信 息 的 引入 。 
【分 析 】 

本 题目 介绍 了 taglib 指令 的 用 法 ,首先 运行 a. jsp 页 面 ,在 页 面 上 显示 了 一 个 表格 ， 
内 容 为 本 章 一 些 题 目的 链接 ,在 页 脚 处 引用 a. tag 文件 显示 一 些 版 权 信 息 。 
【运行 效果 】 

打开 开发 工具 MyEclipse, 在 上 一 个 题目 所 建立 的 工程 jsp-yufa 中 的 WebRoot 文件 
夹 下 ,新 建 工 程 文件 a.jsp, 在 WEB-INF 文件 夹 下 新 建文 件 夹 tags, TE tags 文件 夹 中 新 建 
a. tag 文件 (如 图 3-13 和 图 3-14 所 示 )。 程 序 输 入 完毕 并 且 保 存 之 后 ,运行 开发 工具 
MyEclipse 中 的 Tomcat 服务 器 。 最 后 在 浏览 器 中 输入 地 址 http://127. 0. 0. 1:8080/ 
jsp-yufa/a. jsp 就 可 以 看 到 运行 结果 了 (如 图 3-15 所 示 ) 。 
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本 页 面 使 用 taglib 指 令 
Copyrightk2011 E-mail :sunqian_teacher@163. com 


图 3-15 a.jsp 页 面 


【 源 代码 】 
[a. tag] 
1 <%@ tag pageEncoding="UTF-8"%> 
2 <center> 
3 <p><hr width="95%" size="2" color=" # AA4E11"></hr></p> 
4 <table width="90%" align="center"> 
5 <tr><td align="center" >4 i if fi JH taglib 48 </td></tr> 
6 <tr><td align: 
4 </table> 
8 </center> 
[a. jsp] 
1 <%@ page contentType="text/HTML; charset—gb2312" language— "java" %> 


2 <%@ taglib prefix— "tags" tagdir— "/WEB-INF/tags" % > 
3 <HTML> 


center" >Copyright&2011 E-mail: sungian_teacher@163.com</td></tr> 


4 <head> 

5 <title>taglib $i f9| — / title 

6 </head> 

7 <body> 

8 <table width — "400" border="1" align="center" cellpadding — "8" cellspacing — "0" 
bordercolor— " # 999999" > 


9 <tr> 

10 <td align="center" rowspan="1" colspan= "2"> fif 3i 3---JSP iik </td> 
11 </tr> 

12 <tr> 

13 <td align="center"> MA 1</td> 

14 <td><a href="exl_1.jsp"> ER 4 BET fi] </a></td> 

15 </tr> 

16 <tr> 

17 <td align="center"> HH 2</td> 

18 <td><a href="qj_time. jsp" >H H = fa lli R— /a7 </td> 
19 </tr> 

20 <tr> 

21 <td align="center"> WH 3</td> 

22 <td><a href= "ex3. HTML" €3& </a></td> 

23 </tr> 


24 </table> 

25 <tags:a/> 

26 </body> 

27 </HTML> 
【补充 说 明 】 
a. tag 代码 说 明 

代码 中 书写 的 内 容 为 一 些 版 权 信息 ,相当 于 自己 定制 的 一 个 标签 。 
a. jsp 代码 说 明 

第 2 行 是 使 用 taglib 指令 引入 标签 , 即 a. tag 代码 页 的 内 容 , 其 中 标签 的 前 级 为 tags, 标 
签 路 径 为 /WEB-INFVtags; 第 25 行 表示 在 这 个 位 置 插入 标签 ,前 缀 名 为 tags, 标 记名 为 a。 
taglib 指令 

taglib 指令 用 于 定义 一 个 标签 库 及 其 自 定义 标签 的 前 级 。taglib 指令 用 于 声明 此 
JSP 文件 中 使 用 了 自 定义 的 标签 ,同时 引入 标签 库 , 并 指定 它们 的 前 级 。 

标记 文件 的 扩展 名 为 . tag. 它 与 JSP 文件 一 样 可 以 引入 其 他 的 标签 文件 的 内 容 。 此 
外 ,标签 文件 必须 放 在 网 站 根 目录 下 的 /WEB-INFVtags/ 目 录 或 其 子 目 录 下 ,如果 标签 文 
件 被 包装 成 JAR 文件 , 则 需要 放 在 /WEB-INF/lib/ 目 录 下 。 

语法 格式 如 上 面 例题 所 用 : 


<%@ taglib prefix— "tags" tagdir="/WEB-INF/tags" %> 

其 中 prefix 属性 定义 的 字符 串 为 标记 前 缀 ,在 JSP 页 面 中 使 用 自 定义 标记 时 ,一般 格 
KAMA: 标记 名 二 ,标记 名 为 标记 库 中 自 定义 标记 的 具体 名 称 。 上 面 题 目 中 前 级 为 
tags, 标 记名 为 a。 
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3.5 JSP 动作 include, param, forward 


【题目 】 

本 题 要 完成 学 生 和 教师 的 分 别 登录 功能 。 
【分 析 】 

题目 用 5 个 页 面 完 成 ,分 别 是 ex3. html, ex3. jsp .ex3_1. jsp、ex3_2. jsp return. jsp. 
我 们 设计 ex3. html 网 页 是 分 权限 登录 界面 ,在 这 个 界面 需要 设计 一 个 表单 ,表单 中 有 一 
个 表格 ,在 表格 中 有 两 个 文本 框 用 于 输入 用 户 名 和 密码 ; 有 两 个 单 选 按钮 用 于 选择 不 同 
的 权限 ; 一 个 重 置 按钮 用 于 重新 输入 信息 ; 一 个 提交 按钮 用 于 提交 界面 的 信息 到 ex3. jsp 
代码 页 。ex3. jsp 代码 页 是 没有 界面 设计 的 ,在 此 代码 页 中 需要 使 用 request 内 置 对 象 的 
get 方法 接收 ex3. html 页 面 提交 的 登录 信息 ,然后 通过 一 个 if 条 件 语句 来 判断 不 同 的 权 
限 ,使 用 forward 动作 将 不 同 权 限定 位 到 不 同 的 二 级 页 面 ,并 且 使 用 param 动作 配合 
forward 动作 使 登录 信息 能 够 继续 传递 到 不 同 权限 的 二 级 页 面 中 。 网 页 ex3_1. jsp 是 学 
生 权 限 登 录 的 二 级 页 面 ,ex3_2.jsp 是 教师 权限 登录 的 二 级 页 面 ,代码 页 中 使 用 include 动 
作 来 引入 return. jsp 代码 页 ,为 的 是 在 二 级 页 面 中 能 够 显示 登录 人 员 的 登录 信息 。 
return, jsp 代码 页 使 用 request 内 置 对 象 的 get 方法 接收 登录 人 员 的 登录 信息 ,并 且 使 用 表 
达 式 的 方法 输出 登录 信息 。return. jsp 代码 页 中 的 代码 是 ex3_1. jsp 页 面 和 ex3_2. jsp 页 面 
能 够 公用 的 代码 ,所 以 把 这 部 分 代码 使 用 一 个 代码 页 单独 写 出 来 ,然后 在 应 用 的 时 候 使 用 
include 动作 来 引用 ,这 样 就 不 用 分 别 在 ex3_1. jsp 页 面 和 ex3_2. jsp 页 面 中 写 入 重复 的 代码 了 。 
【运行 效果 】 

打开 开发 工具 MyEclipse, 在 上 一 个 题目 所 建立 的 工程 jsp-yufa 中 的 WebRoot 文件 夹 
下 ,新 建 工 程 文件 ex3. html, ex3. jsp、ex3_1. jsp、 [Fr seme CENE 
exà 2. jsp. return. jsp。 程 序 输入 完毕 并 且 保 | uu 


BPS: [ 
存 之 后 ,运行 开发 工具 MyEclipse 中 的 Tomcat Eom [ 
服务 器 。 最 后 在 浏览 器 中 输入 地 址 http:// @ 学 生 os v 
127. 0. 0. 1:8080/jsp-yufa/ ex3. html 就 可 以 看 到 运 gl = 
行 结果 了 (如 图 3-16 一 图 3-18 所 示 ) 。 图 3-16 ex3. html 登录 界面 
[J OJEE gi J Oise XS = 
这 是 学 生 登 录 页 面 ! 这 是 教师 登录 页 面 ! 
用 户 名 为 :abe 密码 为 :123 用 户 名 为 :sunqian 密码 为 :456 
返回 登录 首页 返回 登录 首 - 


图 3-17 ex3_1.jsp 学 生 界 面 图 3-18 ex3 2. jsp 教师 界面 
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【 源 代码 】 
【ex3. html] 


1 <HTML> 

2 <head> 

3 <title>JSP EGR </title> 

4 </head> 

5 <body> 

6 <form method="post" action="ex3.jsp"> 
T 

8 


<center> 
<table width="500" border="0" cellspacing — "0" cellpadding — " 10" bgcolor = 
"£FFFFCC"— 
9 <tr> 
10 <td width="250" align="center"> HP 4 : </td> 
11 <td width="263"><input type="text" size="20" name="username" /></td> 
12 </tr> 
13 <tr> 
14 <td align="center">% &-nbsp; 码 : </td> 
15 <td><input type="password" size— "20" name— "password" /></td> 
16 </tr> 
17 <tr> 
18 <td align="center"> 
19 <input type="radio" checked — "checked" value= "student" name= "select" /> 
</td> 
20 <td> 
21 <input type="radio" value="teacher" name= "select" />% ii </td> 
22 </tr> 
23 <tr> 
24 <td align="center"> 
25 <input type="submit" name="login" value= "$226" /></td> 
26 <td><input type="reset" name= "reset" value— "3 5 "/></td> 
27 </tr> 
28 </table> 
29 </center> 
30 </form> 
31 </body> 
32 </HTML> 
[ex3. jsp] 

1 <%@ page contentType="text/HTML; charset=gb2312" language="java" %> 
2 <HTML> 
3 <head> 
4 «uide 3MEBIE </title> 
5 </head> 
6 <body> 
7 <% 
8 String user, pwd, choice; 
9 user= request. getParameter( "username" ) ; 


10 pwd= request. getParameter( " password") ; 
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11 choice— request. getParameter( " select") ; 

12 ifCchoice. equals( " student") ) ( 

13 %> 

14 去 上 -如 果 是 学 生 登录 则 将 页 面 定 向 到 ex3_1 . jsp--> 

15 <jsp:forward page="ex3_1.jsp"> 

16 <jsp:param name= "username" value="<%=user% >"/> 
17 <jsp:param name= "password" value="<%=pwd% >"/> 
18 </jsp:forward> 

19 <% 

20 Jelse( 

21 6n 

22 二 !-- 如 果 是 教师 登录 则 将 页 面 定 向 到 ex3. 2. jsp--> 

23 <jsp:forward page="ex3_2.jsp"> 

24 <jsp:param name= "username" value="<%=user% >"/> 
25 <jsp:param name= "password" value="<%=pwd% >"/> 
26 </jsp:forward> 

27 <% 

28 } 

29 5n 

30 </body> 


31 </HTML> 
[ex3 1.jspl 


<%@ page contentType— "text/ HTML; charset=gb2312" language— "java" % > 
<HTML> 
<head> 
<title> ah (FIRE </title> 
</head> 
<body> 
<center> 
这 是 学 生 登 录 页 面 ! 
«P2 —jsp:include page="return. jsp" ></jsp:include> </P> 
10 </center> 
11 </body> 
12 </HTML> 


oonan A wN 


[ex3 2. jsp] 


<%@ page contentType— "text/ HTML; charset— gb2312" language— "java" 9677 
<HTML> 
<head> 
<title> HRA </title> 
</head> 
<body> 
<center> 
这 是 教师 登录 页 面 ! 
<P><jsp:include page= "return. jsp"></jsp:include> </P> 
10 </center> 
11 </body> 


( 0 - Oo c & ot 
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12 </HTML> 


(return. jsp) 


1 <%@ page contentType="text/HTML; charset=gb2312" language— "java" %> 
2 <HTML> 
3 <head> 
4 «ule 2 MEIBIE </title> 
5 </head> 
6 <body> 
ri <center> 
8 <% 
9 String user, pwd; 
10 user= request. getParameter(" username") ; 
11 pwd- request. getParameter(" password") ; 
12 n 
13 p» H PA :<%=user%> BH :<%=pwd%> </p> 
14 «P2 a href="ex3. HTML" >% AERA BW </a></P> 
15 </center> 
16 </body> 
17 </HTML> 
【补充 说 明 】 
ex3. html 代码 说 明 


第 6 行 到 第 30 行 是 一 个 完整 的 表单 ,定义 表单 的 数据 最 终 提交 到 ex3. jsp 页 面 执 
fi: 第 8 行 到 第 28 行 是 表单 中 的 表格 ,表格 分 为 4 行 2 列 , 每 一 组 一 tr 之 二 /tr 之 就 表示 
表格 的 一 行 ; 第 11 行 是 表格 的 第 1 行 第 2 列 ,在 这 个 位 置 放置 一 个 文本 框 , 用 于 输入 用 
户 名 ,变量 名 为 username; 第 15 行 是 表格 的 第 2 行 第 2 列 ,在 这 个 位 置 放置 一 个 文本 框 ， 
用 于 输入 密码 ,变量 名 为 password; 第 19 行 和 第 21 行 是 表格 的 第 3 行 第 1 列 和 第 2 列 ， 
在 这 两 个 位 置 放置 两 个 单 选 按钮 ,初始 值 分 别 设置 为 student 和 teacher, 变 量 名 都 设置 为 
select; 第 25 行 和 第 26 行 是 表格 的 第 4 行 第 1 列 和 第 2 列 , 在 这 两 个 位 置 放置 两 个 按钮 ， 
一 个 用 于 提交 表单 的 数据 ,一 个 用 于 重新 填写 登录 信息 。 
ex3.jsp 代码 说 明 

第 7 行 到 第 13 行 是 程序 片 ,其 中 第 9 行 到 第 11 行 是 接收 ex3. html 页 面 表单 传递 过 
来 的 用 户 名 、 密 码 .角色 选择 ; 第 12 行 是 一 个 条 件 语句 ,用 来 根据 不 同 的 角色 执行 不 同 的 
任务 ; 第 15 行 到 第 18 行 是 使 用 forward 动作 对 页 面 进行 重新 定向 ,并 且 使 用 param 动 
作 把 本 页 面 的 参数 传递 到 forward 动作 指定 的 页 面 中 ; 第 23 行 到 第 26 行 也 是 使 用 
forward 动作 和 param 动作 配合 来 完成 参数 的 传递 和 页 面 的 重新 定向 。 
ex3 1.jsp 和 ex3 2. jsp 代码 说 明 

第 9 行使 用 include 动作 .引入 了 return. jsp 页 面 。 
return, jsp 代码 说 明 

第 10 行 和 第 11 行 接收 用 户 名 和 密码 的 参数 ,这 两 个 参数 是 ex3. jsp 代码 页 中 param 
动作 传递 到 ex3 1. jsp 和 ex3_2. jsp 页 面 中 的 参数 ,因为 return. jsp 代码 页 是 被 ex3_1. jsp 和 
ex3_2.jsp 文件 引入 的 ,所 以 可 以 接收 这 两 个 参数 。 
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351 《 jsp:includey 动作 标记 


去 jsp:include> 动 作 标记 用 于 向 当前 的 页 面 中 包含 其 他 的 文件 ,这 个 文件 可 以 是 动 
态 文件 也 可 以 是 静态 文件 。 该 标识 的 使 用 格式 如 下 : 


<jsp:include page 一 "被 包含 文件 的 路 径 " /> 
如 上 面 例题 中 用 到 的 : 

<jsp:include page="return.jsp"></isp:include> 
该 标记 也 用 于 向 被 包含 的 动态 页 面 中 传递 参数 ; 


<jsp:include page 二 "被 包含 文件 的 路 径 " > 
<jsp:param name— " £A f" valude— " 35 (f" /> 
</jsp:include> 


如 下 面 例题 中 用 到 的 : 


<jsp:include page— "ex8 1.jsp" > 

—jsp: param name— "a" value="<%=a%>" /> 

<jsp:param name— "b" value="<%=b%>" /> 

</jsp:include> 

(1) Page 属性 指定 了 被 包含 文件 的 路 径 , 其 值 可 以 是 一 个 代表 了 相对 路 径 的 表达 
式 。 当 路 径 是 以 “/” 开 头 时 , 则 按照 当前 应 用 的 路 径 查 找 这 个 文件 ; 如 果 路 径 是 以 文件 名 
或 目录 名 称 开头 ,那么 将 按照 当前 的 路 径 来 查找 被 包含 的 文件 。 

(2) 二 jsp:param 记 子 标识 可 以 向 被 包含 的 动态 页 面 传递 参数 。 


352 < jsp:include> 动作 标记 与 include 指 令 标记 的 区 别 


如 果 使 用 <jsp:include 二 动作 标记 .被 包含 文件 的 语法 和 人 逻辑 独立 于 当前 页 面 ,单独 
被 编译 ,当前 页 面 执行 时 再 单独 处 理 包 含 文件 的 速度 较 慢 ,但 是 可 以 与 param 标记 组 合 
使 用 ,这 样 更 加 灵活 ,如 果 遇 到 需要 传递 参数 的 情况 更 适合 使 用 二 jsp: include > zh fF 
标记 。 

如 果 使 用 include 指令 ,被 包含 文件 在 include 指令 的 地 方 插入 ,与 当前 页 面 合并 成 一 
个 文件 ,一 同 执行 ,执行 速度 比 一 jsp:include 二 动作 标记 要 快 。 所 以 如 果 不 需要 传递 参数 
的 情况 下 ,include 指令 更 适 于 使 用 。 


353 param 动 作 


<jsp: param 记 动作 标记 不 能 单独 使 用 ,必须 作为 jsp: include, jsp: forward, jsp: 
plugin 标记 的 子 标记 使 用 ,并 为 它们 提供 参数 。 
语法 格式 如 下 : 


<jsp:param name 一 "参数 名 字 " value= "T EMS Ec (8 " /> 
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例如 : 


<jsp:forward page="ex3_2.jsp"> 

<jsp:param name="username" value="<_%=user% >"/> 
<jsp:param name="password" value="<_%=pwd% >"/> 
</jsp:forward> 


当 该 标记 作为 jsp:include 的 子 标记 时 ,name 和 value 为 页 面 之 间 提 供 参数 传递 。 
354 fomard 动 作 


过 jsp:forward 写 动作 将 客户 端 发 来 的 请 求 重 定向 到 另 一 个 JSP、Servlet 或 HTML 
文件 中 。 语 法 格式 如 下 : 


<jsp:forward page 一 "要 转向 的 页 面 URL] <% = RER A>" /> 
或 者 


<jsp:forward page 一 "要 转向 的 页 面 URL | <A —383k53X 6" > 
<jsp: param name 一 "属性 名 "value 一" 属性 值 | <%= 335352" /> 
</jsp:forward> 


例如 : 


<jsp:forward page="ex3_2.jsp"> 

<jsp:param name="username" value= "< % = user% >"/> 
<jsp:param name="password" value="<%=pwd% >"/> 
</jsp:forward> 


实战 演练 2 一 比较 大 小 


【题目 】 

在 页 面 中 显示 文件 什么 时 候 被 加 载 ,什么 时 候 加 载 完 毕 , 并 且 完 成 两 个 参数 的 传递 和 
比较 大 小 。 
【分 析 】 

本 题目 需要 新 建 两 个 文件 ex8. jsp .ex8_1. jsp 来 完成 所 有 的 操作 ,在 ex8. jsp 中 主要 
完成 的 是 使 用 include 和 param 动作 完成 文件 的 加 载 和 参数 值 的 传递 ; 在 ex8_1.jsp PE 
要 完成 的 是 参数 值 的 接收 和 声明 一 个 能 够 完成 比较 大 小 功能 的 方法 。 

【运行 效果 】 

打开 开发 工具 MyEclipse, 在 上 一 个 题目 所 建 foe 127.0.0.1 Ë ^s BHA 
立 的 工程 jsp-yufa 中 的 WebRoot 文件 夹 下 ,新 建 工 [5 TO 
程 文件 ex8. jsp、ex8_1. jsp。 程 序 输 入 完毕 并 且 保 | 仿 : "本 开关 加 载 。 

存 之 后 ,运行 开发 工具 MyEclipse 中 的 Tomcat 服 | Fhe: 

务 器 。 最 后 在 浏览 器 中 输入 地 址 http://127. 0.0. | Ss ERAS tes. 
1:8080/jsp-yufa/ex8. jsp 就 可 以 看 到 运行 结果 了 | 主页 画 信 息 ， 现在 已 经 加 载 完毕 。 

(如 图 3-19 所 示 ) 。 图 3-19 ex8. jsp 页 面 


[动态 网 站 设计 与 制作 一 J5P ] 


<%@ page contentType="text/html; charset=gb2312" language— "java" 967» 


<title>include 和 param 444 f£i JH — / title 


ex8_1.jsp 文 件 , 求 两 个 数 的 最 大 值 :下 面 开始 加 载 。 


【 源 代码 】 
[ex8. jsp] 
1 
2 <html> 
3 <head> 
4 
5 </head> 
6 <body> 
T <% int a710,b—9; 67 
8 去 p> 主 页 面 信息 : 加 载 
9 <jsp:include page= "ex8 1.jsp" > 


="a" value="<%=a%>" /> 


10 <jsp:param name 

11 —jsp: param name="b" value="<%=b%>" /> 
12 </jsp:include> 

13 </p> 

14 <pr ERMA: 现在 已 经 加 载 完毕 。 

15 </p> 

16 </body> 

17 </html> 


【ex8_1. jsp] 


<%@ page contentType="text/html; charset=gb2312" language— "java" %> 


1 

2 <html> 

3 <head> 

4 <title></title> 
5 </head> 
6 

7 

8 

9 


<body> 
<% ! public String bijiaoCint x, int y) ( 
if (x>y){ 
int temp; 
10 temp— x; 
11 x=y; 
12 y=temp; 
13 ) 
14 return (" 大 数 是 "十 y 十 ", 小 数 是 "十 x); 
15 } 
16 n 
17 <% 
18 int x= Integer. parseInt( request. getParameter("a")) ; 
19 int y= Integer. parseInt( request. getParameter("b")) ; 
20 %> 
21 <p> A3 HIF tte FE Be d c (RO S | </p><br/> 
22 接收 到 ex8. jsp 文件 传递 过 来 的 参数 是 a— — 96 — x96 7, &nbsp; &nbspsb=<%=y%>, 
<br/> 
23 比较 大 小 的 结果 : <% =bijiao(x, y) 67 
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24 </body> 
25 </html> 


【补充 说 明 】 
ex8. jsp 代码 说 明 

第 9 行 是 使 用 include 动作 加 载 ex8_1. jsp 文件 ; 第 10 行 到 第 11 行 是 使 用 param 
动作 给 两 个 变量 赋值 并 且 传 递 到 被 加 载 的 文件 ex8_1. jsp; 第 12 行 表 示 include 动作 
结束 。 
ex8_1. jsp 代码 说 明 

第 7 行 到 第 16 行 是 一 段 方法 声明 ,这 个 方法 用 来 比较 ex8. jsp 文件 传递 过 来 的 变量 
值 的 大 小 ,并 且 有 结果 返回 值 ; 第 17 行 到 第 20 行 是 接收 ex8. jsp 文件 传递 过 来 的 变量 
值 ,而 且 还 为 这 两 个 变量 做 了 整形 的 强制 转换 ; 第 22 行 是 输出 本 页 面 接收 到 的 两 个 变 
量 值 ; 第 23 行 是 调用 本 页 面 声明 的 方法 来 对 两 个 变量 的 大 小 进行 比较 ,得 出 结果 并 
输出 。 


3.6 useBean 动 作 


JSP 中 的 useBean 动作 就 是 使 用 Bean, Bean 是 JavaBean 的 简称 ,实际 上 它 就 是 
Java 开发 中 的 一 个 类 ,通过 封装 属性 和 方法 成 为 具有 某 种 功能 和 接口 的 类 。 更 简化 一 些 
来 说 ,Bean 就 是 一 个 类 ,useBean 动作 就 是 “使 用 类 ”的 动作 。 

JSP+JavaBean 是 JSP 开发 的 一 种 典型 模式 ,Sun 的 JavaBean 技术 为 JSP 开发 提供 
了 极 大 的 方便 ,JavaBean 是 一 个 可 重复 使 用 的 软件 组 件 , 使 得 页 面 与 数据 处 理 实现 了 真 
正 的 分 离 。 


实战 演练 全 一 应 用 JavaBean 实现 图 书库 存 的 录入 并 显示 


【题目 】 

使 用 useBean 动作 设计 一 个 图 书 的 入 库 输 入 并 显示 的 操作 平台 (不 使 用 数据 库 ) 。 
【分 析 】 

要 使 用 useBean 动作 来 完成 此 题 ,首先 应 该 创建 一 个 图 书 的 Bean。 在 这 个 Bean 中 
要 包括 图 书 名 称 和 库存 的 get 和 set 方法 。 本 题 需要 两 个 界面 来 完成 操作 ,一 个 界面 用 于 
录入 ; 另 一 个 界面 用 于 显示 。 还 有 就 是 要 解决 图 书 录 入 时 的 汉字 识别 问题 。 所 以 综合 下 
来 本 题 总 共 需 要 四 个 文件 ,cart. java( 图 书 的 Bean? , kucun. html( 录 入 界面 )、kucun_ 
bean. jsp( 显 示 结 果 页 面 ) .hzsb.jsp( 用 于 汉字 识别 的 代码 ) 。 
【运行 效果 】 

首先 创建 Bean. tI AFETA MyEclipse, 在 工程 jsp-yufa 的 src 文件 夹 中 新 建 一 个 
用 于 放置 Bean 的 文件 夹 bean( 如 图 3-20 和 图 3-21 所 示 )。 然 后 在 bean 文件 夹 中 新 建 类 
cart( 如 图 3-22 和 图 3-23 所 示 )。 在 新 建 好 的 cart. java 文件 中 输入 程序 源 代码 然后 保存 。 
当 程 序 运行 之 后 ,cart. java 文件 会 自动 转换 成 cart. class 以 供 程 序 运 作 使 用 。 
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图 3-20 $È JavaBean 的 包 
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图 3-21 新 建 包 名 称 为 bean 
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图 3-22 在 bean 包 中 新 建 类 


在 工程 jsp-yufa 中 的 WebRoot 文件 夹 下 ,新 建 工 程 文件 kucun. html 和 kucun_ 
bean. jsp。 程 序 输 入 完毕 并 且 保 存 之 后 .运行 开发 工具 MyEclipse 中 的 Tomcat 服务 器 。 
最 后 在 浏览 器 中 输入 地 址 http://127. 0. 0. 1:8080/jsp-yufa/ kucun. html 就 可 以 看 到 运 


行 结果 了 (如 图 3-24 一 图 3-26 所 示 )。 
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™New Java Class 


Java Class 
dh Type name is discouraged. By convention, Java type Q 
names usually start with an uppercase letter 


Source folder: isp-yufa/sre 
D JavaBeanff)setüge: C 
Package: bean 
口 Enclosing tye: ERED > 图 书库 存 
BRER: 

i [cart| - km. 
Modifiers: CO public O default 

Oabstract O final = 
Superclass: java. lang. Object B 

图 3-23 类 名 为 cart 图 3-24 kucun, html 


口 JavaBean 的 set 和 ge DJavaBean 的 set 和 ge 


图 书 管理 》》 图 书库 存 | getProperty 
MBER: 《页 事 大 王 》 
图 书 名 称 ， < 故事 大 王 》 
ER. ips 
库存 ， 55 
B) (aca) 
Hi 3-25 在 kucun. html 页 面 输入 图 书 图 3-26 kucun_bean. jsp 
库存 信息 
【 源 代码 】 
[cart. java] 
1 package bean; 
2 public class cart ( 
3 private String bookname; 
4 private int num; 
5 public cart() { 
6 bookname=""; 
T num=0; 
8 } 
9 public cart(String bookname, int num) { 
10 this. bookname— bookname; 
11 this. num— num; 
12 ) 
13 public String getbookname( ) { 
14 return( bookname) ; 
15 ) 
16 public void setbookname(String bookname) { 
17 this. bookname— bookname; 
18 ) 
19 public int getnum() { 
20 return(num) ; 
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22 public void setnum(int num) { 
23 this. num— num; 

24 ) 

25 } 


【kucun. html] 


1 <html> 

2 <head> 

3 <title>JavaBean AY set 和 get R fl — / title 

4 </head> 

5 <body> 

6 <form method="post" action="kucun_bean. jsp" name="form1"> 

7 <table width="90%" border="1" align="center" cellpadding="8" cellspacing — "0" 
bordercolor="  CC9900" bgcolor=" # FFFFCC"> 


8 <tr> 
9 <td height="30" colspan="2" align="left" valign="middle" 
bgcolor=" # CCCCCC"> [8 45 # 8 ) ) FAB HE FE</td> 
10 </tr> 
11 <u> 
12 <td align="right" valign="middle" width="40%"> A454 f : </td> 
13 <td align="left" valign="middle" > 
14 <input type="text" name= "bookname" id="textfield2"/></td> 
15 </tr> 
16 <u> 
17 <td align="right" valign="middle" >H: </td> 
18 <td align="left" valign="middle" > 
19 <input type="text" name— "num" id= "textfield3"/></td> 
20 </tr> 
21 <tr> 
22 <td colspan— "2" align="center" valign="middle" > 
23 <input type="submit" name="button" id= "button" value 一 "确定 "” /> 
24 <input type— "reset" name="button2" id— "button2" value= "3E Bt". /></td> 
25 </tr> 
26 </table> 
27 </form> 
28 </body> 
29 </html> 
[hzsb. jsp] 


<%@ page contentType— "text/html;charset— gb2312" language— "java" %> 
<%! 
public String hzsb(String s) 
{ 
String str=s; 
try 


{ 


Yaukhwne 


8 byte b[ ]=str. getBytes("ISO-8859-1") ; 
9 str=new String(b) ; 

10 return str; 

11 ) 

12 catch( Exception e) 

13 (return str;} 

14 ) 

15 4 


[kucun bean. jsp] 


1 <%@ page contentType-— "text/html;charset— gb2312" language "java" %> 

2 <%@ include file="hzsb. jsp" %> 

3 <html> 

4 <head> 

5 <title>JavaBean 的 set 和 get A fi] </title> 

6 </head> 

7 <body> 

8 <% 

9 String bookname= hzsb( request. getParameter("bookname" ) ) ; 

10 int num= Integer. parseInt( request. getParameter("num") ) ; 

11 %> 

12 <jsp:useBean id 一 "book" class= "bean. cart" scope— "page" /> 

13 <jsp:setProperty name= "book" property— "bookname" value— "— ?6 = bookname% >"/> 

14 <jsp:setProperty name— "book" property— "num" value="<%= num% >"/> 

15 <table width — "9026" border— "1" align="center" cellpadding — "10" cellspacing — "0" 

bordercolor— " # CC9900" bgcolor=" # FFFFCC"> 

16 <tr> 

17 <td colspan="2" align="left" valign="middle" bgcolor=" # CCCCCC" fii JH 
javabean 技术 的 setProperty 属性 设置 参数 值 , getProperty 属性 获取 参数 值 : 
</td> 

18 </tr> 

19 <tr> 

20 <td align="center" valign="middle" width— "4026" MBA: </td> 

21 <td align="left" valign— " middle" — 

22 <jsp:getProperty name— "book" property="bookname"/><br></td> 

23 </tr> 

24 

25 "center" valign="middle" > &nbsp; &nbsp; &-nbsp; & nbsp; EF: </td> 

26 <td align="left" valign="middle" > 

27 <jsp:getProperty name="book" property="num"/><br></td> 

28 </tr> 


29 </table> 


30 <p align="center" ><a href— "js. jsp">i& [2l | ij; H 30 28 JL ifi </a> 


31 </body> 
32 </html> 
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【补充 说 明 】 
cart, java 代码 说 明 

第 1 行 表 示 cart, java 在 bean 这 个 文件 夹 中 ; 第 2 行 到 第 25 行 是 一 个 完整 的 cart 
类 的 声明 ,这 里 大 家 应 该 已 经 发 现 cart 类 是 一 个 公共 类 ,类 的 名 字 是 MyEclipse 工具 自 
动 生成 的 并 且 与 文件 名 相同 ,因为 在 程序 运行 的 过 程 中 ,cart. java 将 转变 成 cart. class 
提供 给 程序 使 用 ,所 以 公共 类 的 名 字 与 文件 名 相同 非常 重要 。 第 3 行 到 第 4 行 是 cart 
类 中 的 两 个 私有 变量 ,bookname 表示 图 书 名 称 ,num 代表 图 书库 存 ; 第 5 行 到 第 8 行 
是 cart 类 的 构造 函数 ,是 不 带 参 数 的 ,用 于 对 cart 的 对 象 进行 初始 化 ; 第 9 到 第 12 行 
也 是 cart 类 的 构造 函数 ,是 带 参 数 的 ,用 于 对 cart 的 对 象 进行 初始 化 ; 第 13 行 到 第 
15 行 是 获取 图 书 名 称 的 方法 ,可 以 返回 图 书 名 称 的 字符 串 ; 第 16 行 到 第 18 行 是 设置 图 
书 名 称 ; 第 19 行 到 第 21 行 是 获取 图 书库 存 ,可 以 返回 整形 值 ; 第 22 行 到 第 24 行 是 设置 
图 书库 存 。 
kucun. html 代码 说 明 

这 个 页 面 是 做 的 界面 设计 ,第 6 行 到 第 27 行 是 一 个 完整 的 表单 ,表单 中 的 数据 将 要 
提交 到 kucun_bean. jsp 代码 页 ; 第 7 行 到 第 26 行 是 一 个 表格 ,表格 总 共有 4 行 2 列 ; 代 
码 第 8 行 到 第 10 行 是 表格 的 第 一 行 ,这 行 把 两 个 单元 格 合并 为 1 个 ,并 且 设 置 了 该 行 的 
格式 和 颜色 等 属性 ; 代码 第 11 行 到 第 15 行 是 表格 的 第 二 行 , 这 行 的 第 二 个 单元 格 放置 
了 一 个 文本 框 , 用 于 接收 输入 图 书 名 称 的 字符 串 , 变 量 名 为 bookname; 第 16 行 到 第 
20 行 是 表格 的 第 三 行 , 这 行 的 第 二 个 单元 格 放置 了 一 个 文本 框 ,用 于 接收 输入 库存 的 字 
符 串 ,变量 名 为 num; 第 21 行 到 第 25 行 是 表格 的 第 四 行 ,这 行 的 两 个 单元 格 合并 为 1 个 ， 
放置 了 两 个 按钮 一 个 用 于 提交 表单 的 数据 ,另外 一 个 用 于 表格 内 容 的 重新 输入 。 
hzsb. jsp 代码 说 明 

这 是 一 段 对 汉字 进行 解码 的 程序 .request 对 象 在 获取 提交 的 汉字 字符 时 ,会 出 现 乱 
码 ,解决 方法 就 是 将 字符 串 用 ISO-8859-1 进行 编码 ,并 将 编码 放 到 一 个 字 节 数组 中 ,然后 
再 用 这 个 字 节 数组 创建 String 对 象 即 可 。 
kucun_bean. jsp 代码 说 明 

第 2 行 表 示 引 入 hzsb. jsp 文件 ; 第 8 行 到 第 11 行 接收 kucun. html 表单 提交 的 图 
书 名 称 和 库存 的 数据 ,并 且 把 图 书 名 称 做 了 汉字 识别 转换 ,把 库存 做 了 强制 整形 转换 ; 
第 12 行 表 示 使 用 useBean 动作 ,在 此 动作 中 用 到 的 类 是 bean 包 下 的 cart 类 ,建立 类 的 
对 象 是 book, 使 用 范围 是 pages 第 13 行 表示 设置 对 象 book 的 bookname 属性 值 为 
kucun. html 表单 传递 过 来 的 图 书 名 称 ; 第 14 行 表 示 设 置 对 象 book 的 num 属性 值 为 
kucun. html 表单 传递 过 来 的 库存 量 ; 第 15 行 到 第 29 行 是 一 个 完整 的 表格 ,总 共有 3 行 
2 列 ; 第 16 行 到 第 18 行 是 表格 的 第 一 行 , 在 这 行 里 把 两 个 单元 格 做 了 合并 ,并 且 设 置 了 
单元 格 的 对 齐 方 式 和 颜色 ; 第 19 行 到 第 23 行 是 表格 的 第 二 行 , 在 这 行 显示 图 书 的 名 称 ， 
其 中 第 二 个 单元 格 也 就 是 代码 第 22 行 是 获取 对 象 book 的 bookname 属性 值 ; 第 24 行 到 
第 28 行 是 表格 的 第 三 行 ,在 这 行 显示 图 书 的 库存 ,其 中 第 二 个 单元 格 也 就 是 代码 第 
27 行 是 获取 对 象 book 的 num 属性 值 ; 第 30 行 是 一 个 其 他 页 面 的 链接 ,与 后 面 的 习题 
相关 联 。 
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361 创建 Bean 


Bean 分 为 可 视 化 组 件 和 非 可 视 化 组 件 , 非 可 视 化 的 Bean 被 广泛 地 使 用 在 JSP 编程 
中 。 上 面 的 例题 就 是 属于 非 可 视 化 的 组 件 。 非 可 视 化 Bean 的 一 些 规定 如 下 。 


1. Bean 的 构造 方法 


Bean 就 是 符合 一 定 条 件 的 Java 类 ,该 类 必须 声明 为 public 类 型 ,可 供 其 他 类 实例 
化 。 类 中 如 果 有 构造 方法 ,必须 声明 为 public 类 型 。 构 造 方法 也 就 是 我 们 常 说 的 构造 函 
数 ,构造 方法 是 一 种 特殊 的 方法 ,具有 以 下 特点 。 

(1) 构造 方法 的 方法 名 必须 与 公共 类 名 相同 。 

(2) 构造 方法 没有 返回 类 型 ,也 不 能 定义 为 void, 在 方法 名 前 面 不 声明 方法 类 型 。 

(3) 构造 方法 的 主要 作用 是 完成 对 象 的 初始 化 工作 ,所 以 构造 方法 可 以 没有 参数 也 
可 以 有 多 个 参数 , 它 能 够 把 定义 对 象 时 的 参数 传 给 对 象 的 域 。 

(4) 构造 方法 总 是 伴随 着 new 操作 一 起 调用 。 

(5) 一 个 类 可 以 定义 多 个 构造 方法 ,如 果 在 定义 类 时 没有 定义 构造 方法 , 则 编译 系统 
会 自动 插 和 人 一 个 无 参数 的 默认 构造 器 ,这 个 构造 器 不 执行 任何 代码 。 


2. Bean 的 属性 与 方法 


Bean 的 属性 必须 声明 为 private, 方 法 必须 声明 为 public 类 型 。Bean 中 用 一 组 set 方 
法 设置 Bean 的 私有 属性 值 ,get 方法 获得 Bean 的 私有 属性 值 。set 和 get 方法 名 称 与 属 
性 名 称 之 间 必 须 对 应 ,也 就 是 : 如 果 属 性 名 称 为 xxx, 那 么 set 和 get 方法 的 名 称 必 须 为 
setxxx() 和 getxxx() ,set 和 get 为 前 级 与 属性 名 字 首 字母 大 写 组 成 set 和 get 方法 名 称 。 
另外 ,创建 Bean 必须 带 有 包 名 。 


362 < jspiuseBean>》 动作 标记 
1. <jsp:useBean> 3) 4% 4i it 


要 想 在 JSP 页 面 中 使 用 Bean. VA Jof JH <jsp: useBean> a fF gc ic fE vi hi P E 
一 个 Bean 的 实例 ,这 个 被 定义 实例 有 一 定 的 生存 范围 及 一 个 唯一 的 id,JSP 页 面 通过 id 
来 识别 Bean ,也 可 以 在 程序 片 中 通过 id. method 形式 来 调用 Bean 中 的 set 和 get 方法 。 
下 面 是 useBean 动作 标记 的 使 用 格式 : 


二 jsp:useBean id— "bean 名 字 " scope 一 "page| request| session | application" class— "packageName. 
calssName"/> 


上 面 题目 中 的 用 法 : 


一 jsp:useBean id 一 "book" class— " bean. cart" scope 一 "page" /> 


这 句 话 中 ,使 用 到 的 类 是 bean 包 下 的 cart 类 ,book 是 类 的 对 象 ,使 用 范围 是 page. 
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2. 使 用 范围 分 类 


(1) Bean 的 作用 范围 是 page: 同一 个 客户 访问 的 每 个 页 面 的 Bean 对 象 是 互 不 相同 
的 ,它们 占用 不 同 的 存储 空间 , 当 客 户 离开 这 个 页 面 时 ,释放 占用 的 内 存 空间 。 不 同 客户 
访问 同一 页 面 时 ,Bean 之 间 互 不 干扰 。 

(2) Bean 的 作用 范围 是 session: 同一 个 客户 在 访问 同一 个 站 点 的 不 同 ISP 页 面 时 ， 
只 要 Bean 的 id 相同 ,范围 是 session ,该 客户 使 用 的 就 是 同一 个 Bean ,无 论 在 哪个 页 面 对 
Bean 的 属性 进行 了 改变 ,其 他 页 面 都 能 看 到 。 不 同 客户 之 间 的 Bean 是 不 同 的 、 互 不 影 
响 的 。 

(3) Bean 的 作用 范围 是 request: 同一 个 客户 在 request 作用 范围 内 ,请 求 与 相应 之 
间 共 用 一 个 id 的 相同 的 Bean, 请 求 响应 完成 时 Bean 即 被 释放 ,不 同 客户 的 Bean 互 不 
相同 。 

(4) Bean 的 作用 范围 是 application: 同一 站 点 下 的 所 有 用 户 共享 一 个 Bean ,任何 客 
户 对 Bean 的 修改 都 会 影响 其 他 客户 。 


363 < jsp:setProperty> 动作 标记 

使 用 二 jsp:setProperty 记 动作 标记 可 以 在 JSP 页 面 中 设置 Bean 实例 的 属性 ,但 必须 
保证 Bean 有 对 应 的 setxxx 方法 。 

使 用 格式 如 下 : 

<jsp:setProperty name 一 "Bean XR AJA FR" property =" MEZ" value="<%= expression %>" /> 
上 面 题目 中 用 到 的 : 

<jsp:setProperty name— "book" property — "bookname" value="<%= bookname% >"/> 

其 中 name 值 必须 与 二 jsp:useBean 二 中 id 的 值 相同 ,表示 类 的 对 象 ; property 的 值 
是 进行 设置 的 对 象 的 属性 值 ; 表达 式 的 数据 类 型 必须 和 Bean 的 属性 类 型 相 一 致 。 

二 jsp:setProperty 二 命令 有 以 下 四 种 形式 的 用 法 。 

(1) 第 一 种 形式 

<jsp:setProperty name = " Bean 对 象 的 名 称 " property = "* "/> 

该 形式 是 设置 Bean 属性 的 快捷 方式 。 在 Bean 中 属性 的 名 字 、 类 型 必须 和 request 
对 象 中 的 参数 名 称 相 匹配 。 由 于 表单 中 传 过 来 的 数据 类 型 都 是 String 类 型 的 ,JSP 内 在 
机 制 会 把 这 些 参数 转化 成 Bean 属性 对 应 的 类 型 。 

property = " * "A B 44 FHI Bean 属性 名 字 匹 配 的 请 求 参 数 都 将 被 传递 给 相应 
的 属性 set 方法 。 

(2) 第 二 种 形式 


<jsp:setProperty name = " Bean 对象 的 名 称 " property = " propertyName " /> 


使 用 request 对 象 中 的 一 个 参数 值 来 指定 Bean 中 的 一 个 属性 值 。 在 这 个 语法 中 ， 
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property 指定 Bean 的 属性 名 ,而 且 Bean 属性 和 request 参数 的 名 字 应 相同 。 也 就 是 说 ， 
如 果 在 Bean 中 有 setUserName(String userName) 方 法 ,那么 ,propertyName 的 值 就 是 
"userName"。 这 种 形式 灵活 性 较 强 ,可 以 有 选择 地 对 Bean 中 的 属性 赋值 。 

(3) 第 三 种 形式 

< jsp: setProperty name = " Bean 对 象 的 名 称 ”property = "Bean 对 象 的 属性 名 " value = 

"BeanValue"/> 

value 用 来 指定 Bean 属性 的 值 。 字 符 串 数据 会 在 目标 类 中 通过 标准 的 valueOf 方法 
自动 转换 成 数字 .boolean Boolean, byte,Byte,char,Character. fi] Ml. boolean 和 Boolean 
类 型 的 属性 值 ( 比 如 true) 通 过 Boolean. valueOf 转换 ,int 和 Integer 类 型 的 属性 值 (比如 
42) 通 过 Integer. valueOf 转换 。 

(4) 第 四 种 形式 

<jsp:setProperty name = " Bean 对 象 的 名 称 " property = "propertyName" param = "request 对 

象 中 的 参数 名 "/ 二 

param 指定 用 哪个 请 求 参 数 作为 Bean 属性 的 值 。Bean 属性 和 request 参数 的 名 字 
可 以 不 同 。 如 果 当 前 请 求 没有 参数 , 则 什么 事情 也 不 做 ,系统 不 会 把 null 传递 给 Bean 属 
性 的 set 方法。 因此 ,你 可 以 让 Bean 自己 提供 默认 属性 值 ,只 有 当 请 求 参 数 明确 指定 了 
新 值 时 才 修 改 默 认 属 性 值 。 


364 < jsp:getProperty》 动作 标记 


使 用 二 jsp:getProperty 二 动作 标记 可 以 在 JSP 页 面 中 得 到 Bean 实例 的 属性 值 ,并 将 
其 转换 为 String 类 型 的 字符 串 ,发 送 到 客户 端 。 使 用 二 jsp:getProperty 二 动作 标记 ,必须 
先 声明 Bean 的 实例 ,并 保证 Bean 中 有 对 应 的 getXxx() 方 法 。 
语法 格式 如 下 : 


<jsp:getProperty name= "Bean 对 象 名 称 " property 一 "属性 名 "二 
上 面 题目 中 用 到 的 : 
<jsp:getProperty name="book" property="bookname"/> 


其 中 name 值 必须 与 二 jsp:useBean 二 中 的 id 的 值 相同 ,表示 类 的 对 象 ; property 的 
值 是 进行 取 值 的 对 象 的 属性 值 。 


实战 演练 2 一 一 应 用 JavaBean 实现 管理 员 登 录 


【题目 】 

要 求 使 用 useBean 动作 完成 本 题 。 设 计 一 个 管理 员 登 录 的 界面 ,如 果 管 理 员 能 够 顺 
利 登录 就 可 以 进入 图 书 管理 界面 对 图 书 进行 人 库 操作 ; 如 果 管 理 员 登录 失败 就 要 重新 回 
到 登录 界面 ,不 能 进入 图 书 管理 界面 (不 使 用 数据 库 ) 。 

【分 析 】 
使 用 useBean 动作 来 完成 此 题 , 首 先 应 该 创建 一 个 用 于 存放 登录 信息 的 Bean, EX 


> [ 动态 网 站 设计 Si 一 sp] 000 


个 Bean 中 要 包括 登录 的 用 户 名 和 密码 的 get 和 set 方法 ,以 及 用 于 鉴别 登录 信息 是 否 正 
确 的 方法 。 本 题 需要 两 个 界面 来 完成 操作 ,一 个 界面 用 于 登录 ; 另 一 个 界面 用 于 显示 。 
所 以 本 题 共 需要 三 个 文件 ,login. java( 登 录 信息 的 Bean) login. html( 登 录 界 面 ) ,login 
show. jsp( 登 录 结果 显示 界面 )。 
【运行 效果 】 

首先 创建 Bean, 打 开 开 发 工具 MyEclipse, 在 工程 jsp-yufa 的 src 文件 夹 中 已 经 建 好 
的 一 个 用 于 放置 Bean 的 文件 夹 bean 中 新 建 类 login。 在 新 建 好 的 login. java 文件 中 输入 
程序 源 代码 ,然后 保存 。 当 程序 运行 之 后 ,login. java 文件 会 自动 转换 成 login. class 以 供 
程序 运作 使 用 。 

在 工程 jsp-yufa 中 的 WebRoot 文件 夹 下 ,新 建 工程 文件 login. html 和 login show. 
jsp。 程 序 输入 完毕 并 且 保 存 之 后 ,运行 开发 工具 MyEclipse 中 的 Tomcat 服务 器 。 最 后 
在 浏览 器 中 输入 地 址 http://127. 0. 0. 1:8080/jsp-yufa/ login. html 就 可 以 看 到 运行 结 
果 了 (如 图 3-27 一 图 3-29 所 示 ) 。 


javabean 广 法 登录 
RAM, 单 击 这 里 重新 登录 
LITT 
用 户 名 称 ， | m 
用 户 密码 ， | 22 
图 3-27 login. html 登录 界面 图 3-28 login_show.jsp 登录 失败 


欢迎 管理 员 sunqian 登 录 到 库存 页 面 去 工作 ! 


管理 册 但 录 信息 是 
用 户 名 称 ， 


用 户 密码 ， 


图 3-29 login show. jsp 登录 成 功 


【 源 代 码 】 
【login. java] 


1 package bean; 

2 public class login { 

3 private String loginName; 

private String password; 

public void — loginO f 
loginName— null; 
password= null; 

} 

public String getloginName( ) 

{return loginName; } 


PoOMrIane 


o 


11 public void setloginName(String loginName) 
12 (this.loginName — loginName; ) 
13 public String getpassword( ) 
14 (return password; ) 
15 public void setpassword(String password) 
16 [this. password — password; } 
17 public boolean check() 
18 { 
19 if("sunqian" . equals(loginName) & &"sq" . equals( password) ) 
20 return true; 
21 else 
22 return false; 
23 ) 
24 ) 
【login. html] 


1 <html> 

2 <head> 

3 <title>javabean Fi ik 3k </title> 

4 </head> 

5 <body> 

6 <form method="post" action— "login show.jsp" name= "forml" > 

7 <table width— "9094" border= align="center" cellpadding— "10" cellspacing= 
bordercolor— " & CC9900" bgcolor=" € FFFFCC"> 


8 <tr> 
9 <td colspan— "2" align="left" valign="middle" bgcolor=" € CCCCCC" 二 管理 
JA EE [td 
10 </tr> 
11 <tr> 
12 <td width="40%" align="right" valign="middle" JH P! ZPR: </td> 
13 <td align="left" valign="middle" > 
<input type="text" name="loginName" size="20"/></td> 
14 </tr> 
15 <tr> 
16 <td align="right" valign="middle" 二 用户 密码 : </td> 
17 <td align="left" valign="middle" > 
<input type="password" name= "password" size="20"/></td> 
18 </tr> 
19 <tr> 
20 <td colspan="2" align="center" valign="middle" > 
21 submit" name="submit" value= "Aie AE" size="6" /> 


22 "  name="reset" value=" #" size— "6" /></td> 
23 

24 </table> 

25 </form> 

26 </body> 

27 </html> 


[login show. jsp] 


1 <%@ page contentType— "text/html;charset —GB2312" %> 
2 <html> 
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3 <head> 

4 <title>javabean WK ER</title> 

5 </head> 

6 <body> 

7 <jsp:useBean id= "manage" class="bean. login" scope= "page" /> 

8 <jsp:setProperty name="manage" property="*" /> 

9 — if (manage. check()) 

10 6 

11 <h2> KM M 51 <jsp:getProperty name= "manage" property — "loginName" /7 #3 

12 <a href="cart. html"> PJE f£ Jit ifj & LHE !</a> 

13 </h2> 

14 <% 

15 ) 

16 else 

17 {%> 

18 <h2> 3E RAM, iti <a href="login. html" 3X # HH ER</a></h2> 

19 <% > 

20 <p> 

21 <table width="90%" border="1" align="center" cellpadding="10" cellspacing="0" 

bordercolor=" # CC9900" bgcolor=" # FFFFCC"> 

22 <tr> 

23 <td colspan="2" align="left" valign="middle" bgcolor=" # CCCCCC"> F 3l A Y$ 
信息 是 二 /td 二 

24 </tr> 

25 <tr> 

26 <td align="right" valign="middle" width= "40% "> Jl] P! AER: </td> 

27 <td align="left" valign="middle" ><jsp: getProperty name =" manage" property = 
"loginName" /7 — /td7 

28 </tr> 

29 <tr> 

30 <td align="right" valign="middle" — JH P! #3: </td> 

31 <td align="left" valign="middle" >< jsp: getProperty name — " manage" property = 
"password"/></td> 

32 </tr> 

33 </table> 

34 <p align="center" ><a href="js. jsp" >3& Fl 8] i; it M48 9E ifl </a> 

35 </body> 

36 </html> 

【补充 说 明 】 
login. java 代码 说 明 


第 1 行 表 示 login. java 在 bean 这 个 文件 夹 中 ; 第 2 行 到 第 24 行 是 一 个 完整 的 login 
类 的 声明 login 类 是 一 个 公共 类 ,类 的 名 字 是 自动 生成 的 并 且 与 文件 名 相同 ; 第 3 行 到 
第 4 行 是 login 类 中 的 两 个 私有 变量 ,loginName 表示 管理 员 用 户 名 ,password 表示 登录 
密码 ; 第 5 行 到 第 8 行 是 login 类 的 构造 函数 ,是 不 带 参 数 的 ,用 于 对 login 的 对 象 进行 初 
始 化 ; 第 9 行 到 第 10 行 是 获取 管理 员 用 户 名 的 方法 ,可 以 返回 管理 员 名 字 的 字符 串 ; 第 
11 行 到 第 12 行 是 设置 管理 员 用 户 名 的 方法 ; 第 13 行 到 第 14 行 是 获取 登录 密码 的 方法 ， 
可 以 返回 密码 的 字符 串 ; 第 17 行 到 第 23 行 是 一 个 返回 值 为 布尔 值 的 方法 ,用 于 判断 登 
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录 界 面 输 入 的 用 户 名 和 密码 是 否 符合 管理 员 的 默认 值 , 如 果 正 确 则 返回 值 为 true, 否 则 返 
回 值 为 false。 
login. html 代码 说 明 

本 页 面 是 登录 界面 的 设计 。 第 6 行 到 第 25 行 是 一 个 表单 ,表单 中 的 数据 将 要 提交 到 
login show. jsp 代码 页 ; 第 7 行 到 第 24 行 是 一 个 表格 ,表格 总 共有 4 行 2 列 ; 第 8 行 到 
第 10 行 是 表格 的 第 一 行 , 这 行 把 两 个 单元 格 合并 为 1 个 ,并 且 设 置 了 该 行 的 格式 和 颜色 
等 属性 ; 第 11 行 到 第 14 行 是 表格 的 第 二 行 , 这 行 的 第 二 个 单元 格 放置 了 一 个 文本 框 , 用 
于 接收 输入 的 管理 员 用 户 名 ,变量 名 为 loginName; 第 15 行 到 第 18 行 是 表格 的 第 三 行 ， 
这 行 的 第 二 个 单元 格 放置 了 一 个 密码 框 , 用 于 接收 登录 密码 ,变量 名 为 password; 第 
19 行 到 第 23 行 是 表格 的 第 四 行 ,这 行 的 两 个 单元 格 合并 为 1 个 ,放置 了 两 个 按钮 ,一 个 
用 于 提交 表单 的 数据 ; 另 一 个 用 于 表格 内 容 的 重新 输入 。 
login_show.jsp 代码 说 明 

第 7 行 表 示 使 用 useBean 动作 ,在 此 动作 中 用 到 的 类 是 bean 包 下 的 login 类 ,建立 类 
的 对 象 是 manage, 使 用 范围 是 page; 第 8 行 表 示 设 置 对 象 manage 的 属性 值 为 login. 
html 表单 传递 过 来 的 管理 员 用 户 名 和 密码 ,property = " * "表示 所 有 和 manage 对 象 属 
性 名 字 匹 配 的 参数 都 将 被 传递 给 相应 的 set 方法 ,本 题 使 用 这 个 快捷 方法 是 因为 表单 传 
递 的 参数 值 都 是 String 类 型 ,正好 与 login 类 中 属性 的 类 型 是 符合 的 ; 第 9 行 到 第 19 行 
是 一 个 让 条 件 语句 ,通过 调用 manage 对 象 的 check() 方 法 来 判断 login. html 登录 界面 输 
入 的 用 户 名 和 登录 密码 是 否 正确 ,如 果 都 正确 就 输出 带 有 管理 员 登 录 名 字 的 欢迎 语句 和 
去 库存 页 面 的 链接 ,如 果 不 正确 ,就 给 出 重新 登录 的 返回 链接 ; 第 21 行 到 第 33 行 是 一 个 
表格 ,表格 分 为 3 行 2 列 ,无 论 登 录 信 息 正确 与 否 ,都 会 在 第 二 行 第 二 个 单元 格 和 第 三 行 
第 二 个 单元 格 显示 登录 界面 输入 过 的 用 户 名 和 密码 。 


实战 演练 3 一 一 应 用 JavaBean 实 现 网 站 访问 计数 器 


【题目 】 

本 题 要 求 制作 一 个 网 站 访问 计数 器 , 当 同 一 个 用 户 进行 页 面 刷新 或 页 面 跳 转 的 时 候 
不 能 重复 计数 。 
【分 析 】 

本 题 需 要 两 个 Bean ,一 个 是 负责 计数 ,命名 为 saves 另 一 个 负责 检查 是 否 为 首次 访 
问 , 命 名 为 fw。 在 save 类 中 应 该 有 获取 访问 量 的 get 方法 和 实现 访问 量 累计 的 方法 。fw 
类 中 应 该 有 一 个 布尔 变量 用 于 判断 用 户 是 否 为 首次 访问 ,还 应 该 有 一 个 方法 根据 用 户 是 
否 为 首次 访问 的 结果 来 执行 操作 ,如 果 为 首次 访问 就 调用 save 类 中 的 方法 进行 访问 量 累 
计 , 和 否则 直接 调用 save 类 中 的 get 方 法 输出 已 有 的 访问 量 。 

本 题 的 界面 只 需要 一 个 ,界面 需要 显示 访问 量 , 以 及 提供 前 面 两 个 例题 的 链接 。 
【运行 效果 】 

首先 创建 Bean, 打 开 开发 工具 MyEclipse, 在 工程 jsp-yufa 的 src 文件 夹 中 已 经 建 好 
的 一 个 用 于 放置 Bean 的 文件 夹 bean 中 新 建 类 save 和 fw。 在 新 建 好 的 save. java 和 
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fw. java 文件 中 输入 程序 源 代码 然后 保存 。 

在 工程 jsp-yufa 中 的 WebRoot 文件 夹 下 .新 建 工 程 文 件 js. jsp。 程 序 输入 完毕 并 且 
保存 之 后 ,运行 开发 工具 MyEclipse 中 的 Tomcat 服务 器 。 最 后 在 浏览 器 中 输入 地 址 
http://127. 0. 0. 1:8080/jsp-yufa/js. jsp 就 可 以 看 到 运行 结果 了 (如 图 3-30 所 示 )。 

TE E 


KMDR, LEARN, C2kvAa 


本 情境 题目 


2. E33 


图 3-30 js. jsp 网 站 访问 计数 器 
【 源 代码 】 


[save. java] 


1 package bean; 

2 public class save ( 

3 private long counter—0; 

4 public long getCounter( ) 

5 { 

6 return counter; 

7 ) 

8 synchronized public void Counter( ) 
9 { 

10 this. counter+ + ; 


[tw. java] 


1 package bean; 
2 import bean. save; 
3 public class fw { 


4 boolean isCome= false; 
5 public long getCount(save countB) 
6 { 
7 if(isCome= = false) 
8 { 
9 countB. Counter() ; 
10 isCome= true; 
11 } 
12 return countB. getCounter() ; 
13 ) 
14 } 
【js. jsp] 


1 <%@page contentType— "text/html; charset=GB2312" %> 


2 <jsp:useBean id="b" class= "bean. save" scope— "application" > 


3 </jsp:useBean> 

4 <jsp:useBean id— "a" class="bean. fw" scope="session"> 
5 </jsp:useBean> 

6 <html> 
ri 
8 


<head> 
<title> Bl: 网 站 访问 计数 器 一 /title> 

</head> 
10 <body> 
11 <p> 
12 <% 
13 long num; 
14 num=a. getCount(b) ; 
15 %></p> 
16 <table width="500" border="0" align="center" cellpadding="10" cellspacing="0" bgcolor= 

" # FFFFCC"> 
17 <tr> 
18 <td align="center" 之 欢迎 访问 本 站 ,这 是 访问 计数 器 网 页 ,您 是 第 一 %%=num %> 
位 访问 者 二 /td 二 
19 </tr> 
20 <tr> 
21 <td bgcolor=" # CCCCCC" >A t E </td> 
22 </tr> 
23 <tr> 
24 <td align="center" ><a href="kucun. html" 1, E ff J B</a></td> 
25 </tr> 
26 <tr> 
27 <td align="center" ><a href= "login. html" >2 4R 2J </a></td> 
28 </tr> 
29 </table> 
30 </body> 
31 </html> 
【补充 说 明 】 
save. java 代码 说 明 


第 1 行 表示 save. java 在 bean 这 个 文件 夹 中 ; 第 2 行 到 第 12 行 是 一 个 公共 类 save 
的 声明 ; 第 3 行 是 私有 变量 counter 的 声明 并 且 被 赋予 了 初始 值 , 这 个 类 里 面 没 有 构造 函 
数 ,编译 系统 会 自动 插入 一 个 无 参数 的 默认 构造 函数 ,这 个 构造 函数 不 执行 任何 代码 ; 第 
4 行 到 第 7 行 是 获取 访问 数 的 方法 ; 第 8 行 到 第 11 行 是 访问 量 计数 累计 方法 ,这 里 用 
synchronized 来 解决 多 个 线程 同时 访问 同一 个 共享 变量 的 问题 ,也 就 是 说 当 同 一 个 用 户 
在 本 网 站 访问 时 是 不 会 因为 刷新 了 页 面 就 做 访问 数量 的 累计 的 。 
fw. java 代码 说 明 

第 1 行 表示 fw. java 在 bean 这 个 文件 夹 中 ; 第 2 行 引 入 save 类 ; 第 3 行 到 第 14 íT 
是 一 个 公共 类 fw 的 声明 ; 第 4 行 是 私有 变量 isCome 的 声明 ,并 且 被 赋予 了 初始 值 ,这 个 
类 里 面 也 没有 构造 函数 ; 第 5 行 到 第 13 行 是 获取 访问 数 的 方法 ; 第 7 行 到 第 11 行 是 通 
过 布尔 变量 isCome 的 值 判断 用 户 是 否 为 首次 登录 ,如 果 是 首次 登录 ,那么 就 调用 save 类 
中 的 Counter ( ) 方 法 进行 计数 累加 ; 如 果 不 是 首次 登录 就 直接 返回 save 类 中 的 
getCounter() 方 法 的 值 。 
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js. jsp 代码 说 明 

第 2 行 表 示 使 用 useBean 动作 ,在 此 动作 中 用 到 的 类 是 bean 包 下 的 save 类 ,建立 类 
的 对 象 是 b ,使 用 范围 是 application, 这 表示 当 不 同 的 客户 访问 网 站 的 时 候 , 对 网 站 访问 
产生 的 累计 会 延续 下 去 ,这 样 才能 保证 不 同 客户 访问 网 站 时 的 计数 累加 ; 第 3 行 表示 使 
用 useBean 动作 的 结束 ; 第 4 行 表示 使 用 useBean 动作 ,在 此 动作 中 用 到 的 类 是 bean 包 
下 的 fw 类 ,建立 类 的 对 象 是 a, 使 用 范围 是 session, 这 意味 着 客户 在 这 个 站 点 内 刷新 页 面 
或 者 页 面 的 跳 转 b 的 值 都 会 保持 不 变 ; 第 5 行 表示 使 用 useBean 动作 的 结束 ; 第 12 行 到 
第 15 行 是 一 个 程序 片 ,声明 了 一 个 长 整形 的 变量 num, 并 给 它 赋值 为 a. getCount(b), 当 
网 站 被 首次 访问 时 a. getCount(b) 就 相当 于 对 访问 者 做 了 访问 量 的 累计 ; 第 18 行 用 一 个 
表达 式 输出 了 num 的 值 ; 第 24 行 和 第 27 行 是 对 前 面 两 个 习题 的 链接 。 


本 章 小 结 


掌握 JSP 语法 是 学 好 ISP 开发 的 基础 。JSP 网 页 包括 HTML 标签 和 Java 程序 片 ， 
因此 在 Java 中 使 用 的 各 种 数据 类 型 在 JSP 中 均 可 使 用 。Java 程序 片 用 二 % 和 % 二 括 起 
来 。 在 程序 中 加 入 注释 可 增强 程序 的 可 读 性 与 可 理解 性 ,JSP 中 的 注释 分 为 HTML 注释 
和 JSP 注释 两 种 。 

本 章 给 大 家 介绍 的 ISP 指令 标签 有 page 指令 include 指令 和 taglib 指令 。Page 指 
令 定义 JSP 页 面 的 全 局 属性 ; include 指令 用 来 静态 插入 一 个 文件 ; taglib 指令 用 于 声明 
使 用 自 定义 的 标签 。 

JSP 的 动作 较 多 ,有 include, forward, param, useBean, setProperty, getProperty. 
Include 动作 用 来 在 JSP 页 面 中 动态 包含 一 个 文件 ,包括 的 文件 可 以 是 动态 文件 ,也 可 以 
是 静态 文件 ; forward 动作 用 来 重 定 向 网 页 ; param 动作 配合 include 动作 和 forward 动 
作 使 用 ,用 来 设置 这 两 个 动作 的 参数 值 ; useBean 是 指 在 JSP 中 创建 并 使 用 JavaBean d£ 
术 ; setProperty 和 getproperty 分 别 用 来 设置 和 获得 bean 的 属性 值 。 

中 文字 符 处 理 是 JSP 程序 员 常 常 感到 头痛 的 问题 ,如 果 把 获得 的 字符 串 转 换 为 一 个 
byte 数组 ,再 转换 为 字符 串 ,就 可 以 正确 地 显示 中 文 了 。 


本 章 习 题 
1. 下 面 习题 是 关于 表单 信息 提交 并 且 实 现 汉字 识别 的 ,按照 下 面 的 源 代码 在 浏览 器 
中 做 出 如 图 3-31 和 图 3-32 所 示 的 结果 。 DAF X 
【 源 代码 】 HSEUD > 添加 图 书 
[book. jsp] 图 书 名 称 ，| 动 雪 疯 站 开发 六 程 7 


<%@ page contentType=" text/html; charset = gb2312" 
language="java" %> 
<html> 


图 3-31 book. jsp 


) 汉字 的 处 理 


图 书 名 称 出 版 社 
《动态 网 站 开发 教程 > M 清华 大 学 出 版 社 


图 3-32 book show.jsp 


<head> 
«itle DUE HY Mb </title> 
</head> 
<body> 
<form method="post" action="book_show.jsp" name="forml"> 
<table width="500" border="1" align="center" cellpadding — "0" cellspacing — "0" 
bordercolor— " # CC9900" bgcolor=" # FFFFCC"> 


<tr> 
<td height="30" colspan="2" align="left" valign="middle" bgcolor=" # CCCCCC"> 
图 书 管理 )) 添 加 图 书 二 /td 二 
</tr> 
<tr> 


<td height="30" align="right" valign="middle" [E 5 4 f& : </td> 
<td height="30" align="left" valign="middle" > 
<input type="text" name= "bookname" id— "textfield2" /></td> 
</tr> 
<tr> 
<td height="30" align="right" valign="middle" >##: </td> 
<td height="30" align="left" valign="middle" > 
<input type="text" name= "author" id— "textfield3" /></td> 
</tr> 
<tr> 
<td height — "30" alig: right" valign="middle" > th f tE : </td> 
<td height— "30" align="left" valign="middle" > 
<input type="text" name= "publisher" id— "textfield4" /></td> 
</tr> 
<tr> 
<td height="30" align="right" valign— "middle" 3559: </td> 
<td height="30" align="left" valign="middle" > 
<select name= "category" id= "select" > 
<option selected— "selected" > f£ </option> 
<option>#% #</option> 
<option> Æ ff </option> 
<option>#i@</option> 
<option>& /& </option> 
<option>#& fj </option> 
</select ></td> 
</tr> 
<tr> 
<td height="30" colspan="2" align="center" valign="middle" > 


<input type="submit" name= "button" id— "button" value 一 "确定 " /> 
<input type="reset" name="button2" id— "button2" value="HHi" /> 
</td> 
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</tr> 
</table> 
</form> 
</body> 
</html> 


[book show. jsp] 


<%@ page contentType- "text/html; charset=gb2312" language— "java" %> 
<%@ include file— "hzsb.jsp" %> 
<html> 
<head> 
«itle DU HY Ib RE / title 
</head> 
<body> 
<% 
String bookname= request. getParameter( " bookname") ; 
String author— request. getParameter( "author" ) ; 
String publisher— request. getParameter( " publisher") ; 
String category request. getParameter( "category" ) ; 
bookname- hzsb(bookname) ; 
author=hzsb(author) ; 
publisher=hzsb( publisher) ; 
category— hzsb(category) ; 
%> 
<table width="700" border="1" align="center" cellpadding ="0" cellspacing ="0" 
bordercolor=" # CC9900" bgcolor=" # FFFFCC"> 
<tr> 
<td height="30" align="center" valign="middle" bgcolor=" € CCCCCC"> [8 4$ 
名 称 &-nbsp; </td> 
<td height — "30" align="center" valign="middle" bgcolor =" # CCCCCC"> f # & 
nbsp; </td> 
<td height— "30" align="center" valign="middle" bgcolor =" # CCCCCC" 二 出 版 
tt &nbsp; </td> 
<td height="30" align="center" valign="middle" bgcolor =" # CCCCCC" >% $) & 
nbsp;</td> 
</tr> 


<tr> 
<td height="30" align="center" valign="middle" > 
<%=bookname %>&-nbsp;</td> 
<td height="30" align="center" valign="middle" > 
<%=author 9677 & nbsp; </td> 
<td height— "30" align="center" valign="middle" > 
<%=publisher %>&nbsp;</td> 
<td height="30" align="center" valign="middle" > 
<%=category % > &nbsp; </td> 
</tr> 
</table> 
</body> 
</html> 


[hzsb. jsp} 
<%@ page contentType— "text/html;charset— gb2312" language= "java" 967» 
«HY 
public String hzsb(String s) 
{ 
String str=s; 
try 
{ 
byte b[ ] =str. getBytes("ISO-8859-1") ; 
str=new String(b) ; 
return str; 
) 
catch( Exception e) 
(return str;) 
) 
n 


2. 下 面 习题 是 学 生 总 评 成 绩 计算 器 ,可 以 输入 学 生 的 班级 、 姓 名 、8 次 平时 成 绩 、 考 
勤 成 绩 、 期 末 成 绩 , 单 击 “ 计 算 ” 按 钮 可 以 得 出 结果 ,如 图 3-33 和 图 3-34 所 示 。 


p 区 Problens ts Servers E) Console [9 Web Browser ti. oo NOR 

wi | Location|http://127. 0. 0. 1 :8080/3sp-4/score. jsp. 

& 

K 学 期 m om = 
h|uHR 姓名 — oe Pejy 平时 8 Edo ek & 


md] [m )] [oo] 8 | m | [as | [oo im |] fe ] we t 


图 3-33 score. jsp 


X E Problems|% Servers E Console | # Reb Browser ii. oo eGR r; 
aa | Location |http://127. 0. 0. 1:8080/jsp-4/score-1. jsp “o |m 
E a 

P FERA = 不 z 
| 班级 ee Fej Xejo Ees Fate 平时 5 平时 6 平时 7 平时 8 din 期 末 平时 平均 期 未 60% 至 时 30% 总 分 & 


l2Wl-l|aa (90.0 (80.0 |75.0 [85.0 99.0 100.0 66.0 87.0 (8.0 81.0 85.25 52.199999999999996 25.575 |85. 775  — 


图 3-34 score-1. jsp 


【 源 代码 】 


[score. java] 


package bean; 

public class score ( 
private String bj; 
private String xm; 
private Double pl; 
private Double p2; 
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private Double p3; 

private Double p4; 

private Double p5; 

private Double p6; 

private Double p7; 

private Double p8; 

private Double kq; 

private Double qm; 

private double ave=0.0; 
private double avel=0.0; 
private double qm1=0.0; 
public void setBj(String bj) 

{ this. bj=bj; } 

public void setXm( String xm) 
{ this.xm—xm; } 

public void setP1(Double p1) 
{ this.pl=pl; } 

public void setP2(Double p2) 
{ this.p2=p2; } 

public void setP3(Double p3) 
{ this.p3—p3; } 

public void setP4(Double p4) 
{ this.p4=p4; ) 

public void setP5(Double p5) 
{ this.p5=p5; } 

public void setP6(Double p6) 
{ this.p6=p6; } 

public void setP7(Double p7) 
{ this.p7=p7; ) 

public void setP8(Double p8) 
{ this. p8=p8; ) 

public void setKq( Double kq) 
{ this.kq—kq; } 

public void setQm( Double qm) 
{ this.qm=qm; } 

public String getBj() 

{  return(bj); } 

public String getXm() 

{  return(xm); } 

public Double getP1() 

{  return(pl); ) 

public Double getP2() 

{ return(p2); } 

public Double getP3() 

{ return(p3); } 

public Double getP4() 

{  return(p4); } 

public Double getP5() 

{ return(p5); } 
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public Double getP6() 
{ return(p6); } 
public Double getP7() 
{ return(p7); } 
public Double getP8() 
{ return(p8); } 
public Double getKq() 
{ return(ka); ) 
public Double getQm( ) 
{ return(qm) ; } 
public double average() 
{ 
ave=(pl+p2+p3+p4+p5+p6+p7+ p8)/8; 
return(ave) ; 
) 
public double qimo() 
{ 
qml=qm * 0.6; 
return(qm1) ; 
) 
public double pingshi() 
{ 
avel=ave * 0.3; 
return(avel) ; 
) 
public double sum() 
{ 
double sum=kq+avel+qml; 
return(sum) ; 


} 
[score. jsp] 


<%@ page contentType= "text/html; charset=GB2312" %> 
<html> 
<head> 
<title>My JSP 'score. jsp' starting page</title> 
</head> 
<body> 
<form name= "forml" method="post" action="score-1.jsp"> 
<table width="900" border="0" cellspacing="0" cellpadding="0"> 
<tr> 
<td colspan="13" align="center" >“¢ &nbsp; &nbsp; 期 &-nbsp; & nbsp; he &nbsp; 
& nbsp; 绩 一 /td 二 
</tr> 
<tr><td colspan="13" align="center"> &nbsp; </td></tr> 
<tr> 
<td> HR</td> 
<td> % </td> 
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<td> Fat 1</td> 
<td> Fat 2</td> 
<td> Fit 3</td> 
<td> Fit 4</td> 
<td> At 5</td> 
<td> Fit 6</td> 
<td>F it 7</td> 
<td> Fit 8</td> 
<td> </td> 
d BER —/td- 
<td> &-nbsp; </td> 
</tr> 
<tr> 
<td><input name= "bj" type="text" size="5" ></td> 
<td><input name— "xm" type="text" size="5" ></td> 
<td><input name= "pl" size="5" ></td> 
<td><input name="p2" type="text" size="5"></td> 
<td><input name— "p3" type="text" size="5"></td> 
<td><input name="p4" type="text" size="5"></td> 
<td><input name— "p5" type="text" size="5"></td> 
<td><input name= "p6" size="5" ></td> 
<td><input name= "p7" size="5"></td> 
<td><input name= "p8" size="5"></td> 
<td><input name= "kq" size="5"></td> 
></td> 
="button" value=" HH "></td> 


<td><input name="qm" type="text" size= 


<td><input type="submit" name= "button" i 
</tr> 
</table> 
</form> 
</body> 
</html> 


[score-1. jsp] 


<%@ page contentType= "text/html; charset=GB2312" %> 
<html> 
<head> 
<title>My JSP 'score. jsp' starting page</title> 
</head> 
<body> 
<jsp:useBean id— "a" class— "bean. score" scope— "page" /> 
<jsp:setProperty name— "a"  propertyc" * " /> 
<table width— "900px" border— "1" cellspacing— "1" cellpadding="1"> 
<u> 
<td colspan="14" align="center" >%Æ &nbsp; &nbsp; #4 & nbsp; &nbsp; A &nbsp; 
& nbsp; 绩 一 /td 
<td colspan="2" align="center"><a href="score. jsp"> F—^</a> </td> 
</tr> 
<u> 
<td> HER</td> 
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<td> lid </td> 
<td> F At 1</td> 
<td> Ft 2</td> 
<td> Fit 3</td> 
<td> Fr 4</td> 
<td> Ft 5</td> 
<td> Ft 6</td> 
<td> F At 7</td> 
<td> Fit 8</td> 
<td> X </td> 
ud BER /td— 
到 td> 平 时 平均 一 /td> 
aud BER 60% </td> 
<td> F At 30% </td> 
ud Rr Ad 

</tr> 

<tr> 
<td><jsp:getProperty name="a" property="bj"/></td> 
<td><jsp:getProperty name="a" property="xm"/></td> 
<td><jsp:getProperty name="a" property="p1"/></td> 
<td><jsp:getProperty name="a" property="p2"/></td> 
<td><jsp:getProperty name— "a" property="p3"/></td> 
<td><jsp:getProperty name="a" property="p4"/></td> 
<td><jsp:getProperty name= property="p5"/></td> 
<td><jsp:getProperty name="a" property="p6"/></td> 
<td><jsp:getProperty name="a" property="p7"/></td> 
<td><jsp:getProperty name="a" property="p8"/></td> 
<td><jsp:getProperty name="a" property="kq"/></td> 
<td><jsp:getProperty name— "a" property="qm"/></td> 
<td><% =a. average() % ></td> 
<td><% =a. qim) %></td> 


<td><% =a. pingshi() %></td> 
<td><%=a.sum() ></td> 
</tr> 
</table> 
</body> 


</html> 


【学 习 目 标 】 

. 了 解 表单 验证 的 知识 。 

. 掌握 request 对 象 获得 表单 数据 的 方法 。 

- out 输出 各 种 格式 数据 的 方法 。 

. response 对 象 响应 等 方法 。 

. session 对 象 的 生命 周期 和 保存 、 获 取 数 据 的 方法 。 
. 掌握 application 对 象 数据 的 保存 与 获取 方法 。 
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【知识 结构 图 】 


out : 用 于 输出 数据 


request: 用 于 获取 用 户 提交 的 信息 
application : 使 不 同 用 户 在 不 同 页 面 之 间 传送 变量 值 


pageContext ~ config“ | 


JSP 内 置 对 象 概述 

JSP 的 内 置 对 象 是 指 ISP 页 面 系统 中 已 经 默认 设置 的 Java 对 象 ,这 些 对 象 无 须 显 式 
声明 ,直接 就 可 以 在 Java 程序 片 和 表达 式 中 使 用 。 

JSP f PI ELE SS request, response, session ‚application .out .config exception, page 
和 pageContext 对 象 ,这 些 对 象 分 别 完成 不 同 的 任务 。 

request 对 象 封 装 了 客户 提交 的 数据 信息 及 客户 端的 一 些 信息 ,如 客户 端 使 用 表单 提 
交 数 据 ; response 对 象 用 来 对 客户 端 请 求 做 出 响应 ,向 客户 端 发 送 数据 ; session 对象 用 
来 保存 需要 在 与 每 个 用 户 会 话 期 间 保 持 的 数据 信息 ; application 对 象 用 来 在 多 个 程序 或 
者 是 多 个 用 户 之 间 共 享 数据 ; out 用 来 向 客户 端 输出 数据 。 
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4.1 使 用 request 对 象 


实战 演练 reest 计算 器 


【题目 】 

制作 一 个 简单 的 实数 计算 器 ,可 以 完成 加 减 乘除 运算 。 
【分 析 】 

本 题 需 要 做 一 个 界面 设计 ,我 们 假设 对 两 个 操作 数 进行 计算 ,那么 在 界面 上 需要 有 两 
个 文本 框 , 用 来 输入 操作 数 , 四 个 单 选 按钮 分 别 设计 为 不 同 的 操作 (加 \ 减 ,乘除 ) ,一 个 提 
交 按 钮 ,还 有 一 个 接收 操作 结果 的 空间 。 本 题 操 作 结 果 的 获得 需要 使 用 request 对 象 的 
getParameter 方法 来 实现 页 面 间 数据 的 接收 。 总 的 来 说 本 题 需要 两 个 页 面 来 完成 操作 ， 
一 个 是 操作 界面 computer. jsp; 另 一 个 是 后 台 计算 的 代码 cc. jsp. 
【运行 效果 】 

打开 开发 工具 MyEclipse, 新 建 一 个 工程 jsp-nz, 在 这 个 工程 的 WebRoot 文件 夹 下 ， 
新 建 工程 文件 computer. jsp. cc. jsp。 程 序 输入 完毕 并 且 保 存 之 后 ,运行 开发 工具 
MyEclipse 中 的 Tomcat 服务 器 。 最 后 在 浏览 器 中 输入 地 址 http://127. 0. 0. 1: 8080/ 
jsp-nz/computer. jsp 就 可 以 看 到 运行 结果 了 (如 图 4-1 一 图 4-3 所 示 ) 。 


计算 器 
第 一 个 数 操作 第 二 个 数 结果 
ot 
o- 
[Ex] null 
ox 


o+ 


图 4-1 computer. jsp 首次 登录 界面 


5 €T 
计算 器 
第 一 个 数 操作 第 二 个 数 结果 
et 
o- 
123 2 [| null 
ex 
o- 


图 4-2 computer. jsp 输入 操作 数 并 选择 操作 
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CHE bm 
WES 
第 一 个 数 操作 FOR 结果 
ot 
| —3] = — | [5] | 123.0x2.0-246.0 
ox 
o- 
A 4-3 computer. jsp 得 到 结果 
【 源 代码 】 
(computer. jsp] 
1 <%@ page contentType="text/html; charset=gb2312" language= "java" %> 
2 <html> 
3 <head> 
4 <title> i8 d </title> 
5 </head> 
6 <body> 
7 <form name="form1" method="post" action="cc. jsp"> 
8 <table width="90%" border align="center" cellpadding="10" cellspacing="1" 
bgcolor— " # CC9900"> 
9 <tr> 
10 <td colspan= align="center" bgcolor=" # FFFFFF"— il $E 28 </td> 
11 </tr> 
12 <tr> 
13 <td width="25%" align="center" bgcolor=" € FFFFFF" 585 — 4S — /td 
14 <td width— "1576" align="center" bgcolor=" # FFFFFF" &E-— /td— 
15 <td width— "2576" align="center" bgcolor=" # FFFFFF" 58 —4+3&</td> 
16 <td width — "4074" colspan— "2" align="center" bgcolor=" # FFFFFF" > Zi R 
</td> 
17 </tr> 
18 <tr> 
19 <td rowspan="4" align="center" valign="middle" bgcolor=" € FFFFFF"> 
20 <input name="a" type="text" size="8" /></td> 
21 «td bgcolor=" # FFFFFF"> 
22 <input type="radio" name="cz" value= "add"/>+</td> 
23 <td rowspan="4" align="center" valigi middle" bgcolor=" # FFFFFF"> 
24 <input namı type— "text" size /></td> 
25 <td rowspan="4" align="center" valign="middle" bgcolor=" # FFFFFF"> 
26 <input type="submit" name— "buttonl" value=" = "/></td> 
27 <td width="30%" rowspan="4" align="center" valign="middle" bgcolor = 
"£FFFFFF"— 

28 <% String result— request. getParameter("result") ; 967 
29 «M — result %> 
30 </td> 
31 </tr> 
32 <tr> 
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33 <td bgcolor=" # FFFFFF"> 
34 <input type="radio" name= "cz" value= "sub" /7 — </td> 
35 </tr> 
36 <u> 
37 <td bgcolor="  FFFFFF"— 
38 <input type="radio" name= "cz" value= "mul" /7 X </td> 
39 </tr> 
40 <tr> 
41 <td bgcolor=" # FFFFFF"> 
42 <input type="radio" name= "cz" value= "div"/>+</td> 
43 </tr> 
44 </table> 
45 </form> 
46 </body> 
47 </html> 
[cc. jsp] 
1 <%@ page contentType="text/html; charset=gb2312" language= "java" %> 
2 <html> 
3 <body> 


4 <% double a=Double. parseDouble( request. getParameter("a")) ; 
5 double b= Double. parseDouble( request. getParameter("b") ) ; 

6 String cz— request. getParameter("cz") ; 

7 String result— null; 

8 if (cz. equals("add")) 


9 {result 一 a 十 "十 "十 b 十 "一 "十 (a 十 b); 
10 if (cz. equals(" sub") ) 
ll {result=a+"-"+b+"="+(a—b); 
12 if (cz. equals("mul")) 
13 {result=at+" X"+b+"="+(a* b); 
14 if (cz. equals("div")) 
15 {result=at"+"+b+"="+(a/b); 
16 X 
17 <jsp:forward page= "computer. jsp" > 
18 <jsp:param name= "result" value="< % = result% >"/> 
19 </jsp:forward> 
20 </body> 
21 </html> 

【补充 说 明 】 

computer, jsp 代码 说 明 


本 页 面 是 计算 器 的 操作 界面 ,第 7 行 到 第 45 行 是 一 个 表单 ,表单 数据 将 提交 到 
cc. jsp 代码 页 执行 ; 第 8 行 到 第 44 行 是 一 个 表格 ,总 共有 6 行 5 列 ; 第 9 到 第 11 行 是 表 
格 第 一 行 ,这 行 合 并 了 5 个 单元 格 ; 第 12 到 第 17 行 是 表格 第 二 行 ,这 行 总 共有 四 个 单元 
Wt; 第 18 到 第 31 行 是 表格 第 三 行 ,这 行 总 共有 五 个 单元 格 ,分 别 放 置 了 两 个 文本 框 用 于 
输入 操作 数 ,变量 名 分 别 为 a 和 b, 单 元 格 大 小 为 8, 放置 了 一 个 单 选 按钮 ,变量 名 为 cz, 标 
识 为 add, 表 示 这 是 一 个 十 操作 ,一 个 提交 按钮 ,按钮 上 的 文字 修改 为 二 ,第 五 个 单元 格 用 
于 放 阜 计算 结果 ,使 用 request 来 接收 操作 结果 并 使 用 表达 式 输出 显示 到 界面 上 ; 第 
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32 到 第 35 行 是 表格 的 第 四 行 , 放 置 了 一 个 单 选 按钮 ,变量 名 为 cz, 标 识 为 sub, 表 示 这 是 
一 个 一 操作 ; 第 36 到 第 39 行 是 表格 的 第 五 行 ,放置 了 一 个 单 选 按钮 ,变量 名 为 cz, 标 识 
为 mul, 表 示 这 是 一 个 X 操 作 ; 第 40 到 第 43 行 是 表格 的 第 六 行 , 放 置 了 一 个 单 选 按 钮 , 变 
量 名 为 cz, 标 识 为 div, 表 示 这 是 一 个 二 操作 。 
cc. jsp 代码 说 明 

本 页 面 是 对 操作 数 进行 计算 的 代码 页 ,第 4 行 和 第 5 行 是 接收 computer. jsp 页 面 传 
递 过 来 的 两 个 操作 数 ,并 且 强 制 转换 为 Double 类 型 ; 第 6 行 是 对 运算 操作 cz 的 接收 ; 第 
8 行 到 第 15 行 是 使 用 让 条 件 语 句 对 cz 进行 判断 ,然后 根据 匹配 情况 对 两 个 操作 数 进 行 
“加 ”“ 减 ”“ 乘 ”或 “ 除 ” 的 运算 ; 第 17 行 是 对 页 面 的 重 定 向 , 当 操作 数 完成 计算 之 后 就 把 
操作 定位 到 computer. jsp 页 面 显 示 结 果 ; 第 18 行 是 将 本 页 面 得 到 的 结果 传递 到 
computer. jsp 页 面 ; 第 19 行 是 forward 动作 的 结束 标志 。 


request 对 象 


request 对 象 封 装 了 客户 端 提交 的 数据 信息 ,包括 用 户 提交 的 信息 以 及 客户 端的 一 些 
信息 。 客 户 端 可 以 通过 HTML 表单 或 者 在 网 页 地 址 后 面 使 用 参数 的 方法 提交 数据 ,再 
用 request 对 象 的 相关 方法 来 获取 提交 的 各 种 数据 。 

在 Web 程序 设计 中 ,用 户 一 般 是 通过 HTML 表单 提交 信息 的 。 表 单 的 一 般 格式 是 : 

<form method 一 get/post action=" fy Hifi" name 二 "表单 名 字 " > 

提交 手段 部 分 

</form> 

request 对 象 可 以 使 用 getParameter(String s) 方 法 获得 该 表单 提交 的 信息 。 调 用 方 
法 如 下 : 

request. getParameter( String str) 

其 中 ,参数 str 是 指定 的 参数 名 称 , 这 个 方法 是 JSP 程序 设计 中 最 为 常用 的 方法 之 一 。 

request 接收 的 表单 提交 信息 大 多 数 时 候 都 是 String 类 型 的 ,常常 需要 做 类 型 的 转 
换 , 比 如 上 面 例 题 中 用 到 的 : 

Double. parseDouble( request. getParameter( "a") ) 

这 句 代码 中 request 接收 的 String 类 型 的 值 被 转换 为 了 Double 类 型 。 我 们 常用 到 
的 还 有 以 下 几 种 。 

整形 : Integer. parseIntO ; 

浮 点 型 : Float. parseFloatO ; 

long 型 : Lang. parseLang() 。 


实战 演练 2 一 request 选 择 题 


【题目 】 
制作 一 篇 测试 题 , 由 若干 单 选 题 和 多 选 题 组 成 ,题目 完成 后 提交 答案 ,显示 得 分 。 
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【分 析 】 

本 题 需 要 两 个 界面 ,一 个 用 于 制作 测试 题 (exl. jsp); 另 一 个 用 于 处 理 题目 的 正确 率 ， 
得 出 分 数 (exl-answer. jsp)。 在 exl. jsp 中 需要 添加 表单 、 表 格 .若干 单 选 和 多 选 的 按钮 、 
提交 按钮 ; 在 exl-answer. jsp 中 需要 使 用 request 接收 测试 题 页 面 exl. jsp 表单 提交 的 数 
据 , 然 后 判断 对 错 , 得 出 分 数 。 
【运行 效果 】 

打开 开发 工具 MyEclipse, 在 上 一 个 新 建 的 工程 jsp-nz 中 的 WebRoot 文件 夹 下 ,新 
建 工程 文件 exl. jsp. exl-answer. jsp。 程 序 输 入 完毕 并 且 保 存 之 后 ,运行 开发 工具 
MyEclipse 中 的 Tomcat 服务 器 。 最 后 在 浏览 器 中 输入 地 址 http://127. 0. 0. 1: 8080/ 
jsp-nz/exl. jsp 就 可 以 看 到 运行 结果 了 (如 图 4-4 和 图 4-5 所 示 )。 


地 址 (D) | 127.0.0.1 SEZAO Ei] 
搜索 (R) [N SOT. BEBE ORE- 


本 学 期 有 几 门 考试 课 : 


03 02 O1 O4 vsus ] 回 访问 
利 波 特 》 电 影 中 的 邓 布 利多 军队 s 


图 4-4 exl. jsp 测试 题 exl-answer, jsp 得 分 情况 


【 源 代码 】 
[ex1. jsp] 


1 <%@ page contentType="text/html;charset=GB2312"%> 
2 <html> 

3 <head> 

4 <title> At request HY </title> 

5 </head> 

6 <body> 

T <form action= "exl-answer.jsp" method= "post"— 

8 <font color=" £ 336699" size— "4"> 

9 二 p 二 雷锋 纪念 日 是 哪 天 : </p> 


10 "radio" name— "dl" value="a">3 H 15 号 
11 radio" namı dl" value="b">3 A 5 & 
12 <input type="radio" name="d1" value="c">4 H 5.2 
13 <input type="radio" name="d1" value="d">3 月 12 & 
14 <br> 

15 二 p 二 本 学 期 有 几 门 考试 课 : </p> 

16 <input type="radio" name="d2" value="a">3 

17 <input type="radio" name="d2" value="b">2 

18 <input typ radio" nam d2" value="c">1 

19 <input type="radio" name="d2" value="d">4 


20 <br> 


> (asmi weise] 0000 


21 去 p> 下 面 谁 是 ( 哈 利 波 特 ) 电 影 中 的 邓 布 利多 军队 的 成 员 : </p> 
22 <input type="checkbox" name="cl" > i fit = 75 

23 <input type="checkbox" name="c2">44 Bi 

24 <input type="checkbox" name 一 "ec3" 之 马尔 福 

25 <br> 

26 <input type="submit" value= "#2243" name="submit"> 
27 <input type="reset" value= "iB fg "— 

28 </font> 

29 </form> 

30 </body> 

31 </html> 


【exl-answer. jsp] 


1 <%@ page contentType= "text/html; charset — GB2312" % > 


2 <html> 
3 <body> 
4 <font color=" # 336699" size="4"> 
5 <Y%int n=0; 
6 String dl = request. getParameter("d1") ; 
7 String d2— request. getParameter("d2") ; 
8 String cl = request. getParameter("cl") ; 
9 String c2— request. getParameter(" c2") ; 
10 String c3— request. getParameter("c3") ; 
1 if(d1— — null) 
12 {dl= ) 
13 if(d2— — null) 
14 {d2="";} 
15 if(d1.equals("b")) 
16 {n++;} 
17 if(d2.equals("a")) 
18 {n++;} 
19 if(! (cl = — null) & & !(c2==null)) 
20 {n++;} 
21 5» 
22 <p> 8 T<%=n K>B</p> 
23 </body> 
24 </html> 
【补充 说 明了】 
exl.jsp 代码 说 明 


本 页 面 是 选择 题 页 面 ,第 7 行 到 第 29 行 是 1 个 表单 ,表单 的 数据 将 提交 到 
exl-answer. jsp Ail; 第 8 行 设置 了 页 面 中 的 字体 格式 和 字体 大 小 ; 第 9 行 是 段落 标志 ; 
第 10 到 第 13 行 是 在 页 面 中 添加 了 4 个 单 选 按钮 ,名 称 为 dl ,标识 分 别 为 a、.b、c、d, 代 表 
单 选 题 四 个 不 同 的 选项 ; 第 16 到 第 19 行 是 在 页 面 中 添加 了 4 个 单 选 按钮 ,名称 为 42 , 标 
识 分 别 为 a、.b、c、d, 代 表单 选 题 四 个 不 同 的 选项 ; 第 22 到 第 24 行 是 在 页 面 中 添加 了 3 个 
多 选 按钮 ,名 称 分 别 为 cl 、c2、c3, 代 表单 选 题 三 个 不 同 的 选项 ; 第 26 行 是 提交 按钮 ; 第 
27 行 是 重 置 按钮 。 


JSP 内 置 对 象 
exl-answer. jsp 代码 说 明 


本 页 面 是 得 分 页 面 ,第 5 行 ,声明 一 个 变量 n, 用 于 累计 得 分 ; 第 6 行 到 第 10 行 是 接 
收 exl. jsp 页 面 传递 过 来 的 信息 ; 第 11 行 到 第 14 行 表 示 如 果 前 面 两 个 单 选 题 没 做 ,那么 
就 给 答案 赋 空 值 ,这 样 可 以 有 效 预防 选择 题 没 做 而 出 现 的 程序 错误 ; 第 15 行 到 第 19 行 
是 判断 exl. jsp 页 面 传递 过 来 的 信息 是 否 与 标准 答案 符合 ,如 果 符 合 就 可 以 加 分 ; 第 
22 行 是 以 表达 式 输出 得 分 。 


4.2 response 对 象 


实战 演练 全 一 使 用 response 实现 重 定向 


【题目 】 
实现 页 面 的 重 定向 ,分 别 使 用 response 的 无 参数 法 有 参数 法 和 forward 方法 。 
【分 析 】 


题目 需要 三 个 文件 来 完成 ,一 个 界面 设计 文件 response. jsp; 一 个 后 台 设 置 不 同方 式 
完成 页 面 重 定向 的 文件 rr. jsp; 一 个 显示 重 定向 结果 的 页 面 response_1. jsp. TE 
response. jsp 文件 中 需要 一 个 表单 , 放 入 三 个 单 选 按 钮 ,一 个 提交 按钮 ,对 不 同 的 重 定向 
方法 都 设置 好 标识 ; 在 rr. jsp 文件 中 不 需要 界面 的 显示 设计 ,只 负责 根据 response. jsp 
文件 传递 过 来 的 页 面 重 定向 方法 的 标识 来 设置 具体 的 指令 ,并 且 为 能 够 在 页 面 重 定向 的 
时 候 携带 参数 的 指令 准备 好 参数 值 ; response_1. jsp 文件 就 是 最 终 被 重 定向 显示 的 文件 
了 ,根据 不 同 的 重 定向 指令 ,显示 不 同 的 内 容 。 
【运行 效果 】 

打开 开发 工具 MyEclipse, 在 工程 jsp-nz 中 的 WebRoot 文件 夹 下 ， 新 建 工程 文件 
response. jsp. rr. jsp, response_1. jsp。 程 序 输入 完毕 并 且 保 存 之 后 ,运行 开发 工具 
MyEclipse 中 的 Tomcat 服务 器 。 最 后 在 浏览 器 中 输入 地 址 http://127. 0. 0. 1:8080/ 


jsp-nz/ response. jsp 就 可 以 看 到 运行 结果 了 (如 图 4-6 一 图 4-9 所 示 ) 。 


D forwardSisendRedir 

请 选择 网 页 重 定向 的 方式 s [J C: forward 5sendRedir = (BB 
Oresponse, sendRedirect 方 法 1, 不 传递 网 

Oresponse. sendRedirect 方 法 2 可 以 直接 扒 带 参数 NUES adi 


〇 jsp:forward 方 法 可 以 传递 网 页 中 的 参数 


senRe ret AL. 无 法 传递 参数 


图 4-6 首页 response. jsp 


D forwardSjsendRedir * Vs. 


传递 的 r 值 为 ，null 

传递 的 n 值 沟 ，null 

sendRedirect 方 法 1， 无 法 传递 参数 ,但 是 sendRedirect 方 法 2， 
语句 可 以 直接 携带 参数 

sendRedirect 方 法 2， 携 带 的 m 值 为 ，20 


图 4-8 选择 了 response 的 有 参数 传递 重 定向 


图 4-7 选择 了 response 的 无 参数 传递 重 定 向 


[J D forward SsendRedix 


Y 


传递 的 r 值 为 ， A 
传递 的 n 值 为 ， 
isp: fores SEIS REINSAN 


图 4-9 选择 了 forward 的 有 参数 传递 重 定向 
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【 源 代码 】 
[response. jsp] 
1 <%@ page contentType="text/html;charset=gb2312" language= "java" %> 
2 <html> 
3 <head> 
4 <title> forward 与 sendRedirect 的 比较 一 /title> 
5 </head> 
6 <body> 
7 <form action 一 "rr.jsp" method="post" > 
8 请 选择 网 页 重 定向 的 方式 BR 
9 <input type="radio" name="r" value— "sl" CHECKED>response. sendRedirect 方法 
1, 不 传递 网 页 中 的 参数 <BR 二 
10 <input type — "radio" name ="r" value="s2" >response. sendRedirect 方法 2, 可 以 直 
EMiS <BR> 
11 <input type — "radio" name ="r" value="f" >jsp: forward 方法 可 以 传递 网 页 中 的 参 
数 二 BR 二 
12 <input type — "submit" name ="submit" value 一 "确定 "二 
13 </form> 
14 </body> 
15 </html> 
Krr. jsp] 


1 <%@ page contentType— "text/html;charset— gb2312" language— "java" %> 
2 <html> 

3 <head> 

4 <title>My JSP 'rr.jsp' starting page</title> 

5 </head> 

6 <body> 

7 <% 

8 String r= request. getParameter("r") ; 

9 request. setAttribute("n", "10") ; 


10 if(r. equals("s1")) 

11 { 

12 response. sendRedirect("response l.jsp"): 

13 i 

14 ifCr. equals("s2")) 

15 { 

16 response. sendRedirect("response_1.jsp?m=20") ; 
17 } 

18 if(r. equals("f") ) 

19 { 

20 %> 

21 <jsp:forward page="response_1.jsp"> 

22 <jsp:param name="r" value="<% =r %>"/> 
23 </jsp:forward> 

24 <% 

25 } 


26 n 
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27 </body> 
28 </html> 


[response 1. jsp] 


1 <%@ page contentType— "text/html;charset— gb2312" language— "java" 2677 
2 <html> 

3 <head> 

4 «title forward 与 sendRedirect 的 比较 一 /title> 

5 </head> 
6 

7 

8 


<body> 
<% 
String n= (String) request. getAttribute("n") ; 
9 String r= (String) request. getParameter("r") ; 
10 String m= (String) request. getParameter("m") ; 
11 out. println(" 传 递 的 + 值 为 : "+r+"<br/>"); 
12 out.println(" 传 递 的 n 值 为 : "+n+"<br/>"); 
13 if(r!=null) 
14 { 
15 out. print( "jsp: forward 方法 可 以 传递 参数 到 新 的 网 页 "); 
16 } 
17 Else 
18 { 
19 out. print("sendRedirect 方 法 1, 无 法 传递 参数 ") ; 
20 ) 
21 if(m! — null) 
22 { 
23 out. print(", fH Jz sendRedirect 方法 2, 语 句 可 以 直接 携带 参数 "十 "一 br/ 二 "); 
24 out. println("sendRedirect 方法 2, 携带 的 m 值 为 : "t+mt+"<br/>"); 
25 ) 
26 5n 
27 </body> 
28 </html> 
【补充 说 明 】 
response. jsp 代码 说 明 


本 页 面 为 界面 设计 ,第 7 行 到 第 13 行 是 一 个 表单 ,表单 中 的 数据 将 提交 到 rr. jsp 页 
ii; 第 9 行 放置 了 一 个 单 选 按钮 ,变量 名 为 r, 标 识 设置 为 s1, 默 认为 选中 状态 ,代表 了 
response 对 象 不 带 参数 的 页 面 重 定向 方法 ; 第 10 行 放置 了 一 个 单 选 按钮 ,变量 名 为 r, 标 
识 设 置 为 s2 ,代表 了 response 携带 参数 的 页 面 重 定向 方法 ; 第 11 行 放置 了 一 个 单 选 按 
TL ,变量 名 为 r, 标 识 设置 为 f, 代 表 了 forward 指令 页 面 重 定向 方法 ; 第 12 行为 一 个 提交 
按钮 。 
rr.jsp 代码 说 明 

本 页 面 是 根据 r 值 的 不 同 来 确定 重 定向 到 response 1.jsp 页 面 的 方法 。 第 8 行 是 接 
收 response. jsp 页 面 传递 过 来 的 r+ 值 ; 第 9 行 是 设置 n 的 值 为 10; 第 10 行 到 第 13 行 是 
一 个 让 条 件 语 句 , 如 果 r 值 为 sl ,就 使 用 response 无 参数 法 定向 到 response_1. jsp 页 面 ; 
第 14 行 到 第 17 行 是 一 个 计 条 件 语句 ,如 果 值 为 s2. ,就 使 用 response 携带 参数 法 定向 
到 response 1. jsp 页 面 , 传 递 参数 m 一 20 的 参数 值 ; 第 18 行 到 第 25 行 是 一 个 计 条 件 语 
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句 , 如 果 r 值 为 f, 就 使 用 forward 方法 定向 到 response. 1. jsp 页 面 。 
response_1. jsp 代码 说 明 

本 页 面 根据 不 同 的 页 面 定 向 方法 .显示 出 不 一 样 的 结果 。 第 8 行 到 第 10 行 是 接收 
rr. jsp 页 面 传递 过 来 的 参数 ; 第 11 行 到 第 12 行 是 输出 r 的 值 和 输出 n 的 值 ,在 rr.jsp 页 
面 n 的 值 被 request 的 set 方法 设置 了 指定 值 ,如 果 使 用 forward 指令 做 页 面 重 定向 就 可 
以 使 用 request 的 get 方法 再 获得 n 的 指定 值 ; 第 13 行 到 第 19 行 是 一 个 计 条 件 语句 ,如 
果 r 的 值 不 为 空 ,那么 就 表示 参数 值 是 使 用 forward 方法 定向 过 来 的 ,如 果 r 的 值 为 空 , 那 
么 就 表示 参数 值 是 使 用 response 方法 定向 过 来 的 ; 第 20 行 到 第 23 行 是 一 个 if 条 件 语 
名 ,如果 m 的 值 不 为 空 ,那么 就 表示 参数 值 是 使 用 response 的 带 参数 发 传递 过 来 的 。 


421 out 对 象 


Out 对 象 实际 上 是 使 用 PrintWriter 类 向 客户 端 浏览 器 输出 数据 。 

Out 对 象 的 常用 方法 列举 如 下 。 

print() 与 println( ) 方 法 应 用 广泛 ,可 以 输出 各 种 类 型 的 数据 。 

如 上 题 中 使 用 到 的 : 

out. print(", 但 是 sendRedirect 方法 2, 语 句 可 以 直接 携带 参数 "十 "二 br/ 二 "); 
out, println("sendRedirect 方法 2 .携带 的 m 值 为 : "十 m 十 "一 br/ 二 ") 。 


422 response 对 象 


response 对 象 用 于 动态 响应 客户 端的 请 求 , 将 JSP 处 理 数据 后 的 结果 返回 到 客户 端 
浏览 器 。response 是 HttpServletResponse 类 的 一 个 对 象 , 它 与 request 对 象 对 应 。 


1. 重 定向 sendRedirect 


sendRedirect 方法 可 以 将 客户 端 浏览 器 重 定向 到 新 的 Web 页 面 。 使 用 sendRedirect 
可 以 根据 用 户 的 不 同情 况 而 定位 到 不 同 的 页 面 上 去 , 重 定向 语句 之 后 的 代码 将 不 再 执行 。 
例如 ,下 面 语句 就 是 停止 当前 网 页 执行 ,转向 执行 程序 文件 response_1. jsp: 

response. sendRedirect( "response_1.jsp"); 
在 前 面 介绍 过 <jsp: forward 之 也 可 以 重 定向 到 另 一 个 页 面 , 但 两 种 操作 有 如 下 区 别 。 

CD 当 使 用 二 jsp: forward — f&fE EE [6] $8] 53 — A 9t rfi . nT LGB iE — jsp: param f£ 
递 参数 到 新 的 网 页 ,新 的 网 页 使 用 request 对 象 的 getParameter() 方 法 可 以 读 取 参数 的 
值 。 而 使 用 response 对 象 的 sendRedirect ) 方 法 ,不 需要 直接 编码 URL, 就 可 以 实现 传 
递 参数 。 例 如 下 面 语句 在 重 定向 时 传递 了 一 个 名 为 m 值 为 20 的 参数 ,同样 使 用 request 
对 象 访问 参数 m。 


response. sendRedirect("response_1.jsp?m 一 20"); 


String m= (String) request. getParameter("m") ; 


(2) 当 使 用 二 jsp: forward 过 操作 ,两 个 页 面 之 间 可 以 通过 request 对 象 分 享 数据 ,而 
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response 对 象 的 sendRedirect() 方 法 不 支持 这 种 数据 共享 。 也 就 是 说 ,使 用 forward 时 ， 
request 设置 的 属性 (setAttribute) 依 然 能 保留 到 下 一 个 页 面 。 就 如 同上 面 的 例题 中 先 在 
rr. jsp 页 面 使 用 set 方法 设置 了 n 的 值 为 10, 然 后 当 使 用 forward 方法 跳 转 页 面 时 ,在 
response l.jsp 页 面 使 用 get 方法 获取 了 mn 的 值 ,如 图 4-9 所 示 。 


request. setAttribute("n", "10"); 


String n= (String) request. getAttribute("n") ; 


2. 修改 ContentType 属性 


contentType 属性 用 来 设置 JSP 页 面 的 MIME 类 型 和 字符 编码 集 , 取 值 格式 为 
"MIME 类 型 "或 "MIME 类 型 ;charset 一 字符 编码 集 "。JSP 引擎 根据 content Type 属性 ， 
对 用 户 的 请 求 做 出 响应 。response 对 象 可 以 调用 setContentType(String s) 方 法 动态 修 
改 contentType 属性 值 ,JSP 引擎 会 按照 修改 后 的 MIME 类 型 来 响应 客户 浏览 器 。 
MIME 的 中 文 名 为 多 功能 网 络 邮件 扩展 标准 ,也 就 是 说 MIME 是 服务 器 通知 客户 端 接 收 
文件 类 型 的 一 种 手段 。 对 不 同 MIME 类 型 的 文件 ,客户 端 会 指定 不 同 程序 或 插件 打开 ， 
如 flash 动画 指定 其 播放 搬 件 来 播放 。 如 下 面 例题 中 用 到 的 语句 会 指定 Word 软件 来 打 
开 并 保存 当前 页 面 。 


response. setContentType( "application/msword ; charset — GB2312") ; 


3. 定时 刷新 页 面 


HTTP 响应 消息 主要 由 响应 行 、 响 应 头 和 信息 体 组 成 。response 对 象 的 addHeader 
方法 或 者 setHeader 方法 可 以 动态 添加 新 的 响应 头 和 头 值 ,如 果 这 个 头 事先 已 经 存在 , 则 
原来 的 头 被 覆盖 。 使 用 方法 如 下 。 

设置 头 信息 : response. setHeader(" 头 信息 内 容 "," 头 信息 参数 ") ; 

常用 的 刷新 refresh. ff] lll: response. setHeader("refresh"."1"); 

几 秒 后 跳 转 : response. set Header("refresh" "2; URL—XXX'), 


实战 演练 2 一 一 网 页 保存 为 Word 文 档 


【题目 】 

设计 一 个 网 页 ,要 求 的 功能 是 能 把 当前 网 页 保存 为 Word 格式 的 文档 。 
【分 析 】 

使 用 response 对 象 的 setContentType 方法 完成 此 题 。 
【运行 效果 】 

打开 开发 工具 MyEclipse, 在 工程 jsp-nz 中 的 WebRoot 文件 夹 下 ,新 建 工程 文件 
ex2. jsp。 程 序 输 入 完毕 并 且 保 存 之 后 ,运行 开发 工具 MyEclipse 中 的 Tomcat 服务 器 。 
最 后 在 浏览 器 中 输入 地 址 http://127. 0. 0. 1:8080/jsp-nz/ex2. jsp 就 可 以 看 到 运行 结果 
了 (如 图 4-10 一 图 4-12 所 示 )。 


Q (msme weise] 0000 T 


您 想 打 开 或 保存 此 文件 吗 ? 

E 名 称 : ex2. doc 
@response 的 contentType 必 性 设置 ... MOR =) Bee EmA ee ON EN 
RHE) 查看 (VW) KRG) HPL) IAD 帮助 (H) SHER 
所 -日 h AO OKR- sree € QIR- FO 
地 址 (D) |E 12700.1 VEZAO Ea) 回 打开 此 类 文件 之 前 总 是 询问 D 
HEQ[N-WOGCR. HESS Ek ohit- 


"ib RWD” BABS TRA ordri 9 Bon PER ERR EAAS 


图 4-10 ex2. jsp 图 4-11 ex2. doc 下载 


[feci “ETEA Word 文档 ” 按钮 将 当前 页 面 
保存 为 Word 文档 。 


保存 为 Word 文 档 
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Æ 4-12 ex2. doc 


【 源 代码 】 
【ex2. jsp] 


1 <%@ page contentType="text/html;charset=gb2312" %> 

2 <html> 

3 <head> 

4 <title>response 的 contentType Ji fE E </title> 

5 </head> 

6 <body> 

7 <p> Midi“ (REA Word 文档 ”按钮 将 当前 页 面 保存 为 Word 文档 
8 <form action—"" method="post" name="form" > 

9 <input type="submit" name 一 "word" value 一 "保存 为 Word 文档 "二 
10 </form> 


11 <% 

12 String word= request. getParameter("word") ; 

13 if (word= =null) 

14 { word=""; } 

15 if(! word. equals("")) 

16 (response. setContentType( "application/ msword; charset— GB2312") ; } 


17 x» 
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18 </body> 
19 </html> 


实战 演练 3 一 一 网 页 定时 刷新 


【题目 】 

设计 一 个 网 页 ,要 求 的 功能 是 能 把 当前 网 页 每 隔 1 秒 刷 新 1 次 。 
【分 析 】 

使 用 response 对 象 的 setHeader 方法 完成 此 题 。 
【运行 效果 】 

打开 开发 工具 MyEclipse, 在 工程 jsp-nz HY IERI 
WebRoot 文件 夹 下 ,新 建 工 程 文件 ex3.jsp。 程 序 [SFO FEV WRO KRU 工具 SRE 
输入 完毕 并 且 保存 之 后 ,运行 开发 工具 MyEclipse |95* 9 818 G Iwa- vies © 


地 址 (D) [8 127.0.0.1 站 ?ma | 回访 问 


中 的 Tomcat 服务 器 。 最 后 在 浏览 器 中 输入 地 址 feso 可 AEE? 
http://127. 0. 0. 1:8080/jsp-nz/ex3. jsp 就 可 以 看 | masssmuptesiti—i. 

到 运行 结果 了 (如 图 4-13 所 示 ) 。 在 的 时 间 是 10:12:19 

【 源 代码 】 图 4-13 ex3.jsp 
[ex3. jsp] 


1 <%@ page contentType— "text/html; charset— gb2312" import— "java. util. « "957 
2 <html> 

3 <head> 

4 <title>response 的 refresh Ñ tE</title> 

5 </head> 

6 <body> 

7 <% 

8 Date date=new Date() ; 

9 


response. setHeader("refresh" , "1") ; 


10 n 

1 «p WHA 1 秒 钟 刷新 一 次 。 

12 <p> SAE AYE [8] J& &nbsp; &nbsp; 

13 <% — date. getHours() % > :<% = date. getMinutes() % > :<% = date. getSeconds() %> 
14 </body> 

15 </html> 


4.3 session 对 & 


【题目 】 
这 是 一 个 简易 的 购物 练习 ,在 界面 中 输入 顾客 姓名 和 想 要 购买 的 商品 ,然后 在 购物 车 
中 显示 出 顾客 姓名 和 已 经 购买 的 商品 ,实现 这 样 一 个 虚拟 购物 的 过 程 。 


Q [ 动态 网 站 设计 Si 一 sp] 0000 T 


【分 析 】 

题目 需要 三 个 文件 来 完成 ,ex4. jsp 用 于 输入 顾客 姓名 ; first. jsp 用 于 输入 想 要 购买 
的 商品 ; account. jsp 用 于 显示 购物 车 中 的 商品 和 顾客 的 姓名 。ex4. jsp 文件 中 需要 一 个 
表单 提交 顾客 的 姓名 。first. jsp 文件 中 使 用 session 对 象 的 set 方法 存储 顾客 姓名 ,使 用 
一 个 表单 提交 顾客 想 要 购买 的 商品 名 称 。account. jsp 文件 中 使 用 session 对 象 的 get 方 
法 获取 顾客 姓名 ,并 且 调 用 外 部 文件 hzsb. jsp 完成 汉字 识别 的 功能 。 
【运行 效果 】 

打开 开发 工具 MyEclipse, 在 工程 jsp-nz 中 的 WebRoot 文件 夹 下 ,新 建 工程 文件 
ex4. jsp.first. jsp、account. jsp。 程 序 输 入 完毕 并 且 保 存 之 后 ,运行 开发 工具 MyEclipse 
中 的 Tomcat 服务 器 。 最 后 在 浏览 器 中 输入 地 址 http://127. 0. 0. 1:8080/jsp-nz/ex4. jsp 
就 可 以 看 到 运行 结果 了 (如 图 4-14 一 图 4-16 所 示 )。 


on 简易 购物 - 36 
文件 E) 查看 (V) 收藏 @) 帐户 


127.0.0.1 


图 4-14 ex4.jsp 购物 登录 首 界 面 图 4-15 first. jsp 
127001 »| tis | 回访 问 


的 购物 车 


顾客 的 姓名 是 : KIT 


你 购买 的 商品 是 ; FR. SUR. SHE 


图 4-16 account. jsp 


【 源 代码 】 
[ex4. jsp] 
1 <%@ page contentType="text/html;charset=gb2312" language— "java" %> 
2 <html> 
3 <head><title>session ff 4 Ij 4] — / title — / head 
4 <body> 
5 <font color=" # aa2299" size=4> 
6 <p> fi AREA : 
7 <form action= "first. jsp" methed— "post" name="form"> 
8 <input type="text" name= "customer" > 
9 <input type="submit" name— "submit" value 二 "去 购物 "二 
10 </form> 
11 </font> 
12 </body> 


13 </html> 


(igi RES Sinus nase natin aa ak nian Vd Sq UO 情境 四 ISPAB WR Ko 


first. jsp] 
1 <%@ page contentType— "text/html;charset— gb2312" language— "java" 967» 
2 <html> 
3 <body> 
4 <font color=" # aa2299" size=4> 
5 — String c— request. getParameter( "customer" ) ; 
6 session. setAttribute(" xm", c); 
7 %> 
8 去 p> 输 入 你 想 购买 的 商品 : 
9 <form action— "account. jsp" methed="post" name="form"> 
10 <input type="text" name="goods" > 
11 <input type="submit" name= "submit" value= "结账 "过 
12 </form> 
13 </font> 
14 </body> 
15 </html> 
【account. jsp] 
1 <%@ page contentType="text/html;charset=gb2312" language= "java" %> 
2 «XQ include file="hzsb.jsp" %> 
3 <html> 
4 <body> 
5 <font color=" # aa2299" size=4> 
6 <% String name= (String)session. getAttribute("xm") ; 
7 name= hzsb(name) ; 
8 String g= hzsb( request. getParameter( " goods") ) ; 
9 5» 
10 pod HU (gy ae 
11 <p> BUE BER: 
12 «i — name %> 
13 <p> fW SE B R ih HE: 
14 <%=g%> 
15 </font> 
16 </body> 
17 </html> 
[hzsb. jsp] 
1 <%@ page contentType="text/html; charset=gb2312" language= "java" %> 
2 «MW! 
3 public String hzsb(String s) 
4 { 
5 String str=s; 
6 try 
id ( 
8 byte bl ] —str. getBytes("ISO-8859-1") ; 
9 str=new String(b) ; 


10 return str; 


> (aswsm) 7 m 


12 catch( Exception e) 
13 {return str; } 
14 } 
15 A 
【补充 说 明 】 


ex4. jsp 代码 说 明 

第 7 行 到 第 10 行 是 一 个 表单 ,表单 中 有 一 个 文本 框 和 一 个 按钮 ,文本 框 用 于 输入 顾 
客 的 姓名 ,变量 名 为 customer, 表 单 将 把 顾客 姓名 提交 到 first. jsp 文件 。 
first. jsp 代码 说 明 

第 5 行 到 第 7 行 是 Java 程序 片 , 其 中 第 5 行 声明 一 个 字符 串 型 变量 ,使 用 request 
对 象 的 get 方法 接收 ex4. jsp 文件 传递 过 来 的 顾客 姓名 ; 第 6 行使 用 session 对 象 的 set 
方法 设置 变量 xm 的 值 为 c 的 值 , 本 行 代码 使 用 session 对 象 保存 顾客 姓名 变量 的 值 ; 第 
9 行 到 第 12 行 是 一 个 表单 ,表单 中 有 一 个 文本 框 和 一 个 按钮 ,文本 框 用 于 输入 想 要 购买 
的 商品 ,变量 名 为 goods, 表 单 将 把 所 购 商品 提交 到 account. jsp 文件 。 
account. jsp 代码 说 明 

第 2 行 ,使 用 include 指令 引入 hzsb. jsp 文件 ,用 于 识别 汉字 ; 第 6 行 到 第 9 行 是 
Java 程序 片 , 其 中 第 6 行使 用 session XRAY get 方法 获取 xm 变量 的 值 ,可 以 获得 顾客 
的 姓名 ; 第 7 行 是 对 顾客 的 姓名 进行 汉字 识别 ; 第 8 行 声明 字符 串 变量 g 接收 购物 商品 
的 名 称 , 并 且 进 行 汉 字 识 别 ; 第 12 行 输出 顾客 姓名 ; 第 14 行 输出 商品 名 称 。 
431 session 对象 

在 开发 Web 应 用 程序 时 ,开发 者 常会 遇 到 这 样 的 问题 : 当 用 户 浏览 网 站 时 ,如 何 跟 
踪 和 记录 用 户 的 一 些 特定 信息 (如 用 户 身 份 ), 而 不 用 在 每 次 向 服务 器 发 出 请 求 时 都 让 用 
户 验 证 自己 的 身份 。 使 用 session 对 象 就 可 以 解决 这 个 问题 。 当 用 户 请 求 Web 页 面 时 ， 
如 果 该 用 户 还 没有 session 对 象 , 则 Web 服务 器 会 为 该 用 户 创建 一 个 属于 自己 的 session 
对 象 ,存储 用 户 会 话 所 需要 的 信息 。 这 样 , 当 用 户 在 应 用 程序 的 各 Web 页 之 间 跳 转 时 , 存 
储 在 session 对 象 中 的 信息 就 会 在 整个 会 话 过 程 中 一 直 存在 ,直到 会 话 过 期 或 者 被 放弃 ， 
Web 服务 器 才 会 终止 该 会 话 。 

注意 : session 中 保存 的 信息 必须 是 对 象 类 型 ,而 不 能 是 基本 类 型 ,如 果 声 明 为 基本 
类 型 则 需要 转换 。 
432 session 对 象 常用 方法 

Session 对 象 的 常用 方法 如 下 。 


1. setAttribute() 


此 方法 设 定 指定 名 字 的 属性 ,并 将 其 存储 在 session 对 象 中 。 调 用 方法 如 下 : 
setAttribute(String name, java. lang. Object value) 


上 面 例题 中 的 应 用 : 


A SBO ISP AR o 


String c= request. getParameter( " customer") ; 
session. setAttribute(" xm", c) ; 


2. getAttributeQ 


此 方法 获得 指定 的 session 对 象 。 其 调用 方法 如 下 : 
session. getAttribute(String name) 


其 中 ,参数 name 是 指定 session 对 象 的 名 称 。 该 方法 返回 一 个 Object 对 象 , 任 何 对 象 都 
可 加 入 到 session 对 象 中 ,因此 对 返回 的 对 象 要 用 强制 转换 的 方法 ,将 得 到 的 对 象 转 换 为 
此 对 象 原来 的 类 型 。 

上 面 例题 中 的 应 用 : 


String name= (String) session. getAttribute("xm") ; 


4.4 application 对 & 


实战 演练 一 一 使 用 application 制作 站 点 计数 器 


【题目 】 

制作 一 个 站 点 访问 计数 器 ,要 求 不 能 通过 刷新 页 面 累计 访问 量 。 
【分 析 】 

本 题 通 过 一 个 文件 ex5. jsp 即 可 实现 。 文 件 中 声明 一 个 countPeople() 方 法 用 于 累 
计 网 站 的 访问 量 ,如 果 网 站 是 首次 被 登录 就 为 访问 量 count 赋 初 始 值 ,如 果 有 新 的 用 户 访 
问 网 站 就 为 访问 量 count 累加 。 文 件 中 还 需要 有 一 段 程序 片 用 来 判断 用 户 是 否 为 新 登 
3 ,如 果 是 新 登录 就 调用 countPeople() 方 法 ,完成 访问 量 的 累加 。 

【运行 效果 】 

BADIA, MyEclipse, 在 工程 jsp-nz Di m ER 
WebRoot 文件 夹 下 ,新 建 工程 文件 ex5. jsp. HIF [SHO HEV 收藏 @) EPU LA GREF 
输入 完毕 并 且 保 存 之 后 ,运行 开发 工具 MyEclipse | G88- O i9 A G 9ra- Tias O 
中 的 Tomcat 服务 器 。 最 后 在 浏览 器 中 输入 地 址 | mo osi mein 
http://127. 0. 0. 1: 8080/jsp-nz/ ex5. jsp 就 可 以 OEE, 你 是 第 5 人 访问 用 户 。 

看 到 运行 结果 了 (如 图 4-17 所 示 )。 
【 源 代码 】 图 4-17 ex5. jsp 站 点 计数 器 


【exs. jsp] 


1 <%@ page language— "java" contentType 一 "text/html;charset 一 gb2312"% > 
2 «MW! 

3 synchronized void countPeople( ) 

4 { 

5 


ServletContext application= getServletContext() ; 


人 (mammis weise] 000 


6 Integer number= (Integer) application. getAttribute("Count") ; 
7 if(number= = null) 
8 { number— new Integer(1) ; 
9 application. setAttribute("Count" , number); } 
10 else 
11 { number— new Integer( number. intValue() +1); 
12 application. setAttribute( "Count" , number) ; ) 
13) 
14 %> 
15 <html> 
16 <head> 
17 <<title> 不 可 刷新 的 访问 计数 器 二 /title> 
18 </head> 
19 <body> 
20 <% 
21 Integer personnum= (Integer) application. getAttribute( " Count") ; 
22 if(session. isNew() | personnum= — null) 
23 (countPeople() ; } 
24 Integer yournumber= (Integer) application. getAttribute( "Count" ) ; 
25 5n 
26 p We Di [n] a 38 , fs Je 98 — 76 = yournumber %> Vili] JH P 
27 </body> 
28 </html> 

【补充 说 明 】 

ex5. jsp 代码 说 明 


第 2 行 到 第 14 行 是 一 个 方法 声明 ,第 5 行 声 明 ServletContext 类 型 的 变量 
application; 第 6 行 声明 一 个 整形 变量 number 并 赋值 为 Count; 第 7 行 是 一 个 这 语句 ， 
如 果 number 为 空 ,就 说 明 网 站 是 首次 被 访问 ; 第 8 行 是 给 number 赋 初 值 1; 第 9 行使 
用 application 对 象 的 set 方法 给 Count 变量 赋值 为 number 的 值 ; 第 11 行 是 有 新 客户 访 
问 的 情况 下 ,给 访问 量 进行 累加 ; 第 12 行 是 把 更 新 之 后 的 number 值 赋 给 Count; 第 
20 行 到 第 25 行 是 一 个 Java 程序 片 ,第 21 行 声明 一 个 整形 变量 personnum 并 赋值 为 
Count; 第 22 行 是 一 个 庄 条 件 语句 ,如 果 网 站 是 首次 被 登录 或 者 personnum 的 值 为 空 ， 
那么 就 调用 countPeople() 方 法 ; 第 24 行 代码 声明 一 个 整形 变量 yournumber 并 且 赋 值 
为 Count ,如果 没有 新 登录 的 人 员 Count 值 不 变 , 和 否则 yournumber 将 被 赋值 为 新 的 
Count 值 。 


441 application 对 象 


application 对 象 能 够 为 多 个 应 用 程序 保存 信息 ,对 于 一 个 jsp 容器 而 言 , 各 个 用 户 共 
同 使 用 一 个 application 对 象 ,这 是 与 session 对 象 的 最 大 区 别 。 服 务 器 启动 以 后 ,将 自动 
创建 application 对 象 , 该 对 象 能 够 一 直 保 持 , 直 到 服务 器 关闭 为 止 。 


BARRE | 情境 四 JSP 内科 对 象 ] &» 


442 application 对 象 常用 方法 
l. set Attribute() 


该 方法 是 为 应 用 程序 级 变量 赋值 , 若 在 application 对 象 中 还 不 存在 这 个 变量 ,会 添 
加 这 个 变量 。 上 面 例题 中 的 用 法 : 


number 一 new Integer(1) ; 
application. setAttribute( "Count" , number) ; 


2. getAttributeO 


此 方法 得 到 指定 的 application 对 象 在 数据 对 象 的 值 。 其 调用 方法 如 下 : 
application. getAttractive(string name) 
上 面 例题 中 的 用 法 : 


Integer number= (Integer) application. getAttribute("Count") ; 


其 中 ,第 一 个 对 象 name 是 指 application 对 象 中 数据 对 象 的 名 称 ,第 二 个 参数 object 是 这 
个 对 象 对 应 的 值 ,其 类 型 是 Object, 说 明 可 以 是 任意 类 型 ,如 果 对 象 不 存在 , 则 添加 该 对 
Rs 如 果 已 存在 , 则 将 其 覆盖 。 


4.5 综合 实战 演练 : 购物 车 


【题目 】 

本 题 是 一 个 购买 图 书 的 设计 ,需要 在 购物 首 界面 显示 图 书 的 基本 信息 ( 书 名 .单价 .出 
版 社 ) ,并 且 可 以 自己 决定 购买 的 数量 ,然后 跳 转 到 已 购 商品 界面 ,确定 所 购 商 品 准确 无 误 
之 后 可 以 结账 ,也 可 以 在 这 时 进行 删除 或 再 继续 购买 商品 ,在 结算 中 心 可 以 看 到 自己 的 购 
物 清单 合计 。 
【分 析 】 

本 题 需要 三 个 文件 完成 全 部 功能 的 实现 ,分 别 是 购物 文件 goods. html\ 已 购 商 品 文 
TF cart. jsp、 结 算 中 心 文件 cost. jsp. 

在 goods. html 文件 中 需要 设计 一 个 表格 显示 所 有 商品 的 三 个 基本 信息 ,每 个 商品 配 
备 一 个 文本 框 和 一 个 提交 按钮 以 及 三 个 隐藏 组 件 用 来 记录 商品 的 基本 信息 。 

在 cart. jsp 文件 中 需要 设计 一 个 表单 ,表单 中 有 一 个 表格 ,显示 顾客 购买 并 提交 的 商 
品 信息 ,还 需要 给 每 个 商品 配备 一 个 删除 按钮 ,如 果 后 悔 了 就 可 以 不 买 , 另 外 还 有 ”继续 购 
买 商品 ”和 “到 结算 中 心 ”的 链接 。 

在 cost. jsp 文件 中 ,有 一 个 表单 ,表单 中 有 一 个 表格 ,显示 顾客 最 终 决定 购买 的 商品 ， 
并 且 计 算出 所 购 商 品 的 合计 。 


or aeMü5gusWft—ip] 0 0 


【运行 效果 】 

打开 开发 工具 MyEclipse, 在 工程 jsp-nz 中 的 WebRoot 文件 夹 下 ,新 建 工 程 文件 
goods. html、cart. jsp、cost. jsp。 程 序 输入 完毕 并 且 保 存 之 后 ,运行 开发 工具 MyEclipse 
中 的 Tomcat 服务 器 。 最 后 在 浏览 器 中 输入 地 址 http://127. 0. 0. 1:8080/jsp-nz/ goods. 
html 就 可 以 看 到 运行 结果 了 (如 图 4-18 一 图 4-20 所 示 )。 


45.00 | 教育 出 版 社 E EN 


30.00) 教育 出 版 社 | s 


继续 购买 商品 到 结算 中 心 
图 4-19 cart. jsp 已 购 商品 界面 


结算 中 心 
安徒生 童话 45.00 | 教育 出 版 社 2 | 


格林 重活 0.00 | 教育 Hb 版 社 3 | 


| 合计 180.0 | 


图 4-20 cost. jsp 结算 界面 
【 源 代码 】 
[goods. html} 


1 <html> 
2 <head> 
3 <title> WI 4e 3c Bi — / tide 


MEM 情境 四 ISPAB WR &» 


4 </head> 
5 <body> 
6 <hl align="center" >W & nbsp; &nbsp;4#</h1> 
T <table width — "9026" border— "0" align="center" cellpadding — " 10" cellspacing — "1" 
bgcolor=" # CC9900"— 
8 <tr> 
9 <td width="30% "> & nbsp; 34 </td> 
10 td width— "1026" 7 8 ft<br></td> 
1 <td width— "3026" 7 H RE — br — / td 
12 <td width— "3026" — W] 3X 3f lii <br></td> 
13 </tr> 
14 <tr> 
15 <td bgcolor=" # FFFFCC"> &-nbsp; % (E ^E 3E ifi </td> 
16 <td bgcolor=" # FFFFCC">45.00<br></td> 
17 <td bgcolor=" # FFFFCC"> FF thi Mtt <br></td> 
18 <td bgcolor=" # FFFFCC"> 
19 <form method="post" action= "cart. jsp" 
20 <input type="text" name="num" value="1" size="3"> 
21 <input type="submit" value= "HAHH" name= "button6"> 
22 "hidden" value=" % f£ ^E 3E i" name="sm"> 
23 hidden" value— "45.00" name="cost"> 
24 <input type="hidden" value= "ft ff tH itt" name= "cbs" > 
25 </form> 
26 </td> 
27 </tr> 
28 <tr> 
29 <td bgcolor=" # FFFFCC"> &-nbsp; ff ki ifi </td> 
30 <td bgcolor=" # FFFFCC">30.00<br></td> 
31 <td bgcolor=" # FFFFCC"> HA Hh hth <br></td> 
32 <td bgcolor=" # FFFFCC"> 
33 <form method="post" action= "cart. jsp" 
34 <input type="text" name="num" value— "1" size= 
35 <input type="submit" value 一 " 放 到 购物 车 " name="button7"> 
36 <input type="hidden" value 二 "格林 童话 " name="sm"> 
37 <input type idden" value="30.00" name= "cost" > 
38 <input type="hidden" value 王 "教育 出 版 社 " name= "cbs" > 
39 </form> 
40 </td> 
41 </tr> 
42 </table> 
43 </body> 
44 </html> 
[cart. jsp] 


1 <%@ page language— "java" contentType=" text/html; charset=gb2312" % > 
2 <%@ page import="java. util. * " %> 

3 <%@ include file— "hzsb.jsp" %> 
4 

5 


<html> 
<head> 


<title> 3E 85 Ig 9j 4E. — / title 


</head> 
<body> 


<hl align="center" >E &nbsp; W & nbsp; i &nbsp; 品 二 /hl 二 
<% String[ ] goods=new String[4] ; 
goods[0] — request. getParameter("sm") ; 
goods[1] — request. getParameter( "cost" ) ; 
goods[2] — request. getParameter("cbs") ; 
goods[3] — request. getParameter(" num") ; 
Vector goodslist— ( Vector) session. getAttribute("goodscart" ) ; 
ifCgoodslist— = null) 
{ goodslist—new Vector() ; 
goodslist. addElement(goods) ; 
} 
else 
{  goodslist. addElement( goods) ; 
if( request. getParameter( "delgoods") ! = null) 
{ String delgoods= request. getParameter( "delgoods") ; 
goodslist. removeElementAt( Integer. parseInt(delgoods)) ; 


) 
session. setAttribute( " goodscart" , goodslist) ; 


%> 


<table width="90%" border="0" align="center" cellpadding="10" cellspacing="1" 


bgcolor="  CC9900"— 
<tbody><tr> 
<td width="30% "> &-nbsp; H4 </td> 
<td width="10%">% ffr & nbsp; </td> 
<td width="30% ">i Met &-nbsp; </td> 
<td width="10% "> WE &-nbsp; </td> 
<td width— "2026 ">M BR &-nbsp; </td> 
</tr> 
<% if(goodslist! = null) 
for(int x=0;x<goodslist. size() ;x 二 十) 
{ 
String[ ] buygoods; 
buygoods=(String[ ])goodslist. elementAt(x) ; 
if(buygoods[0] ! = null) 
(String sm— hzsb(buygoods[0]) ; 
String cbs— hzsb(buygoods[2]) ; 
n 
<tr> 
<td bgcolor=" # FFFFCC"> &-nbsp;< % =sm% ></td> 
<td bgcolor=" # FFFFCC"> &-nbsp; <% = buygoods[1] % ></td> 
<td bgcolor=" # FFFFCC">&nbsp;< % — cbs 4 ></td> 
<td bgcolor=" # FFFFCC">&-nbsp;< % = buygoods[3] % ></td> 
<td align="center" valign="middle" bgcolor=" € FFFFCC"> 
<form method="post" > &-nbsp; 
<input type="submit" value 二 "从 购物 车 中 删除 " name="button8"> 


54 idden" value= "del" name="del"> 

55 hidden" value=<%=x %> name="delgoods"> 
56 </form></td></tr> 

57 MH) %> 

58 </tbody></table> 


59 <h2 align="center" ><a href="goods. html" > &-nbsp; 4E ££ WK R i </a> 
60 & nbsp; & nbsp; & nbsp; & nbsp; &nbsp;<a href= "cost. jsp" > BAA rnt — /a7 
61 </h2> 

62 </body> 

63 </html> 


[cost. jsp] 


=" 


1 <%@ page language= "java" 
contentType-— "text/html;charset—gb2312" 967» 


2 <%@ page import— "java. util. * " %> 

3 <%@ include file="hzsb. jsp" %> 

4 <html> 

5 <head> 

6 <title> Wd dn BH 4l — / tide 

7 </head> 

8 <body><hl align="center" >% &nbsp;# &nbsp; 中 &nbsp;</h1> 

9 <table width="90%" height —"113" border — "0" align="center" cellpadding =" 10" 
cellspacing — "1" bgcolor=" # CC9900"— 

10 <tr> 

11 <td width="30% "> &-nbsp; 4544 </td> 

12 <td width="10%"> ffr & nbsp; </td> 

13 <td widt 30%" >H hitt & nbsp; </td> 

14 <td width="30% "> WE &nbsp; </td> 

15 </tr> 

16 <% 

17 Vector goodslist= ( Vector) session. getAttribute("goodscart" ) ; 

18 float totalmoney=0; 

19 for(int x=0;x<goodslist. size() ;x ++) 

20 { String[ ] buygoods; 

21 buygoods- (String[ ] ) goodslist. elementAt(x) ; 

22 if(buygoods(0] ! = null) 

23 (String sm— hzsb(buygoods[0]) ; 

24 String cbs— hzsb(buygoods[2]) ; 

25 x» 

26 <u> 

27 <td bgcolor=" # FFFFCC">&-nbsp;< % — sm % ></td> 

28 <td bgcolor=" # FFFFCC"> &-nbsp; <% = buygoods[1] %></td> 

29 <td bgcolor=" # FFFFCC"> 8&-nbsp; <% =cbs % ></td> 

30 <td bgcolor=" # FFFFCC"> &-nbsp; <% = buygoods[3] %></td></tr> 

31 <% totalmoney+ — ( (Float. parseFloat(buygoods[1])) * (Float. parseFloat(buygoods[3]))) ; 

32 ) ) 

33 goodslist. removeAlIElements() ; 


34 n 


Qu (semwmisst de] 7 00 


35 <tr> 
36 <td bgcolor=" # FFFFCC"> &-nbsp; <a href= "goods. html" >38 [2l lg 9] i$ 3t </a> 
</td> 
37 <td bgcolor=" # FFFFCC"> &-nbsp; </td> 
38 <td bgcolor=" # FFFFCC"> &-nbsp; </td> 
39 <td bgcolor=" i£ FFFFCC" >it & nbsp; <% =totalmoney %></td></tr> 
40 </tbody> </table> 
41 </body> 
42 </html> 
【补充 说 明 】 


goods. html 补充 说 明 

第 7 行 到 第 42 行 ,是 一 个 完整 的 表格 ; 第 8 行 到 第 13 行 ,是 表格 的 第 一 行 ,这 行 有 
四 个 单元 格 ; 第 14 行 到 第 27 行 ,是 表格 的 第 二 行 ,这 行 前 三 个 单元 格 是 商品 的 基本 信 
息 , 第 四 个 单元 格 是 一 个 表单 ,表单 信息 将 要 提交 到 cart. jsp 文件 ,表单 中 包含 一 个 文本 
框 ,变量 名 num, 赋 初 值 为 1, 一 个 提交 按钮 ,三 个 隐藏 按钮 用 于 存放 商品 的 三 个 基本 信 
息 , 变 量 名 分 别 为 sm( 书 名 ) .cost( 单 价 )、cbs( 出 版 社 ); 第 28 行 到 第 41 行 ,是 表格 的 第 
三 行 ,这 行 放置 第 二 个 商品 。 
cart, jsp 补充 说 明 

第 2 行 引 入 一 个 util 类 包 ; 第 3 行 引 入 汉字 识别 文件 hzsb.jsp; 第 10 行 声明 一 个 字 
符 串 类 型 的 数组 ,数组 名 称 为 goods ,数组 总 共有 4 个 成 员 ; 第 11 行 到 第 14 行使 用 数组 
的 四 个 成 员 分 别 接收 了 商品 的 书 名 sm .单价 cost、 出 版 社 cbs、 购 买 数 量 num, 这 些 信息 都 
是 由 goods. html 文件 传递 过 来 的 ; 第 15 行使 用 Vector 类 型 定义 了 一 个 向 量 goodslist， 
用 于 存放 商品 信息 ; 第 16 行 是 一 个 if 语句 ,判断 向 量 goodslist 是 否 为 空 , 如 果 为 空 ,就 
表示 顾客 是 首次 购买 ; 第 17 行 到 第 19 行 ,如 果 是 首次 购买 的 情况 ,就 为 向 量 goodslist Hi 
请 一 个 新 的 空间 ,然后 将 数组 goods 中 的 所 有 成 员 信息 都 放 到 goodslist 的 向 量 列表 中 ; 
第 21 行 ,如 果 不 是 首次 购买 ,就 直接 将 数组 goods 中 的 所 有 成 员 信息 都 添加 到 goodslist 
的 向 量 列表 中 ; 第 22 到 第 25 行 , 是 一 组 计 语 句 , 判 断 条 件 是 接收 delgoods 变量 的 值 , 判 
断 是 否 有 需要 从 购买 清单 中 删除 的 商品 ,如 果 delgoods 变量 的 值 不 为 空 ,就 从 goodslist 
的 向 量 列表 中 删除 相对 应 的 商品 ; 第 27 行 ,设置 goodscart 变量 的 值 为 goodslist 向 量 列 
表 的 值 ; 第 29 行 到 第 58 行 是 一 个 表格 ,第 30 行 到 第 36 行 是 表格 第 一 行 标题 行 ; 第 
37 行 到 第 57 行 是 一 组 if FTI KE for 循环 语句 ,首先 判断 如 果 goodslist 向 量 不 为 
Z ,那么 就 把 向 量 列表 中 所 有 的 商品 信息 都 依次 显示 到 表格 下 一 行 相对 应 的 各 个 单元 格 
中 ,并 且 在 每 一 个 商品 后 面 都 对 应 一 个 表单 ,表单 中 有 一 个 删除 按钮 和 一 个 隐藏 按钮 , 隐 
藏 按钮 用 于 标记 是 否 删除 该 商品 ,变量 名 为 delgoods, 删 除 按钮 用 于 执行 表单 的 信息 提 
交 , 默 认 提 交 到 本 文件 中 ; 第 59 行 是 继续 购置 商品 的 链接 goods. html; 第 60 行 是 到 结 
算 中 心 的 链接 cost. jsp。 
cost. jsp 补充 说 明 

第 2 行 引 入 一 个 util 2841; 第 3 行 引入 汉字 识别 文件 hzsb. jsp; 第 9 行 到 第 40 行 是 
一 个 表格 ; 第 17 行 声 明 一 个 Vector 类 型 的 向 量 goodslist 接收 goodscart 的 值 ; 第 19 行 
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到 第 32 行 是 一 个 for 循环 语句 ,用 于 提取 向 量 goodslist 列表 中 各 个 商品 的 信息 显示 在 表 
格 的 相应 单元 格 中 ,并 且 计算 商品 价格 的 累加 得 到 所 有 商品 的 合计 ; 第 33 行 移 除 向 量 
goodslist 中 的 所 有 商品 列表 ; 第 36 行 提供 了 返回 购物 首页 的 链接 goods. html。 


本 章 小 结 


本 章 讲 述 了 ISP 内 置 对 象 的 应 用 ,重点 讲述 了 request, response, session, 
application out 这 五 个 常用 的 对 象 。 

JSP 内 置 对 象 包括 request, response, session, application, out, config, pageContext, 
这 些 对 象 在 服务 器 和 客户 端 交 互 的 过 程 中 分 别 完成 不 同 的 功能 。 


1. Response 
Response 对 象 与 HttpServletResponse 类 关联 ,可 用 来 向 客户 端 输入 数据 。 
2. Session 


Session XJ $2 j HttpSession 类 关联 ,可 用 来 保存 服务 区 端 与 一 个 客户 端 之 间 需 要 保 
留 的 数据 , 当 客 户 端 关闭 网 站 (或 称 为 系统 ) 的 所 有 网 页 时 ,session 变量 会 自动 清除 。 
HTTP 是 一 个 无 状态 协议 ,不 保留 会 话 间 的 数据 ,可 通过 session 对 象 扩展 HTTP 的 功 
能 。 如 果 使 用 page 指令 关闭 了 session, 则 在 此 页 面 中 调用 session 对 象 时 将 导致 错误 ， 
因此 在 工程 实践 中 ,一 般 不 必 关 闭 session, 

Request, response, session 是 JSP 内 置 对 象 中 3 个 重要 的 对 象 ,这 3 个 对 象 提供 了 服 
务 器 端 与 客户 端 ( 即 浏览 器 ) 进 行 交互 通信 的 控制 。 当 客户 端 打开 浏览 器 ,在 地 址 栏 中 输 
和 人 服务 器 Web 服务 页 的 地 址 时 ,是 使 用 HTTP 协议 ,向 服务 器 发 送 了 一 个 请 求 , 服 务 器 
在 收 到 来 自 客户 端 发 送 的 请 求 后 ,通过 response 对 客户 端 进行 响应 ,而 session 就 会 保存 
这 个 会 话 期 间 需 要 使 用 的 数据 信息 。 

请 求 的 方法 有 多 种 , 如 post, get. put. head. delete. trace 等 ,最 常用 的 是 前 两 种 。 
Request 使 response 对 象 还 可 以 操作 HTTP 头 中 的 数据 。 


3. Application 


Application 对 象 与 ServletContext 类 关联 ,一 旦 创建 (在 服务 器 开始 提供 服务 器 时 ， 
即 第 一 个 被 访问 时 application 对 象 就 会 被 创建 ) ,就 会 一 直 保 留 到 服务 器 关闭 服务 为 止 。 
所 以 application 对 象 可 用 来 提供 一 些 全 局 的 数据 和 对 象 。 


本 章 习 题 


1. 教师 在 登录 界面 输入 用 户 名 和 密码 之 后 可 以 进入 教案 编辑 页 面 ,填写 完毕 之 后 可 
以 提交 教案 内 容 。 在 整个 过 程 中 ,从 教师 登录 之 后 ,用 户 名 就 一 直 显 示 在 页 面 上 ,并 且 教 
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案 内 容 可 以 以 中 文 的 形式 填写 和 提交 。 
【分 析 】 

题目 总 共 需 要 四 个 文件 来 完成 ,分 别 命名 为 denglu-t. jsp, plan. jsp, plan-1. jsp. 
hzsb. jsp. 

denglu-t. jsp 文件 是 登录 界面 ,填写 完 登录 信息 之 后 提交 到 plan. jsp 页 面 ,这 个 题目 
中 不 包含 判断 用 户 名 和 密码 是 否 输入 正确 的 功能 。 

在 plan. jsp 文件 使 用 session 对 象 的 set 属性 记录 用 户 名 的 信息 ,从 这 个 页 面 开 始 ， 
后 面 的 页 面 想 要 显示 用 户 名 信息 的 地 方 都 可 以 通过 session WRAY get 属性 获取 用 户 名 。 
这 个 页 面 也 是 制作 教案 的 页 面 ,教案 内 容 填 好 之 后 ,提交 到 plan-1.jsp。 

在 plan-1.jsp 文件 接收 教案 的 全 部 信息 ,并 且 使 用 include 指令 引入 hzsb. jsp 文件 ,在 需 
要 识别 汉字 的 地 方 调用 hzsb() 方 法 来 识别 教案 中 输入 的 全 部 中 文 ,以 便 显示 在 网 页 上 。 
【运行 】 

打开 开发 工具 MyEclipse, 新 建 工 程 plan, 并 在 plan 的 WebRoot 文件 夹 下 新 建 工程 
文件 denglu-t. jsp, plan. jsp, plan-1. jsp, hzsb. jsp. 


用 户 名 : [sa 
程序 输入 完毕 并 且 保 存 之 后 ,运行 Tomcat 服务 器 。 = m Sar | 
PRAE AE sis filial 0. 1:8080/ E 
plan/denglu-t. jsp 就 可 以 看 到 运行 结果 了 (如 - 
图 4-21 ~ [Al 4-23 所 示 ) 。 图 4-21 登录 界面 denglu-t. jsp 
sq 老师 您 已 登录 
授课 教师 日 期 
授课 班级 课时 
授课 内 容 
| 
| 
图 4-22 教案 编辑 页 面 plan. jsp 
sq 老师 您 已 登录 
教案 
授课 教师 HE 日 期 2014-9-2 


授课 班级 12 网 络 班 课时 2 
授课 内 容 JSP 内 置 对 象 ，session 保 存 用 户 信息 


图 4-23 教案 提交 页 面 plan-1. jsp 


2. 本 题 是 在 上 一 题目 的 基础 上 的 拓展 ,这 是 一 个 分 权限 登录 的 系统 ,需要 输入 正确 
的 用 户 名 和 密码 ,并 且 选 择 权限 之 后 才能 登录 ,如 果 是 学 生 登录 ,可 以 做 测验 题 ,在 测验 界 


面 可 以 显示 当前 的 时 间 和 用 户 名 ,并 且 可 以 保存 试题 和 得 出 测验 分 数 。 

如 果 是 教师 登录 ,登录 之 后 可 以 编辑 教案 ,在 这 个 页 面 可 以 显示 当前 的 时 间 和 用 户 
名 ,教案 写 好 之 后 可 以 完成 提交 。 
【分 析 】 

denglu. jsp: 登录 首页 面 。 

teacher. jsp: 设置 了 教师 登录 正确 的 用 户 名 的 密码 。 使 用 session 对 象 的 set 属性 记 
录 了 教师 的 登录 信息 ,后 面 的 页 面 想 要 显示 教师 信息 的 地 方 都 可 以 通过 session 对 象 的 
get 属性 获取 。 

student. jsp: 设置 了 学 生 正确 登录 的 用 户 名 的 密码 。 使 用 session 对 象 的 set 属性 记 
录 了 学 生 的 登录 信息 ,后 面 的 页 面 想 要 显示 学 生 信息 的 地 方 都 可 以 通过 session 对 象 的 
get 属性 获取 。 

denglu-l. jsp: 设置 了 用 户 通过 登录 信息 检测 后 具体 登录 到 哪个 二 级 页 面 。 

time. jsp: 能 够 显示 当前 时 间 。 

test. jsp: 学 生 登 录 之 后 进入 这 个 测验 页 面 , 在 页 面 的 上 方 显示 了 学 生 登 录用 户 名 ， 
通过 session 对 象 的 get 属性 获取 。 页 面 还 能 显示 当前 时 间 ,通过 include 指令 引入 time. 
jsp 实现 。 

test-l. jsp: 学 生 做 过 测试 之 后 可 以 把 题目 提交 ,这 个 页 面 用 于 计算 测验 成 绩 ,并 把 最 
终 成 绩 显 示 在 test. jsp 页 面 。 

plan. jsp: 教师 登录 后 可 以 做 教案 编辑 ,这 个 页 面 显示 了 教师 登录 信息 和 当前 时 间 。 

plan-1.jsp: 教案 编辑 完成 后 提交 到 此 页 面 ,在 这 个 页 面 完 成 显示 教案 全 部 内 容 , 使 
用 request 对 象 的 getParameter 方法 获取 表单 提交 的 值 ,并 且 使 用 汉字 识别 方法 来 完成 
显示 。 

hzsb. jsp: 完成 汉字 识别 功能 。 
【运行 】 

打开 开发 工具 MyEclipse, 新 建 工 程 tz, 并 在 tz 的 WebRoot 文件 夹 下 新 建 工程 文件 


denglu. jsp, denglu-1. jsp, teacher. jsp, student. 


NV . : RPS: |e ] 
jsp,time, jsp, test. jsp, test-1. jsp, plan. jsp, plan- - - 
1 japshasb. sp. RM ASMP ALIA RE | SR [m | 
fi Tomcat 服务 器 。 最 后 在 浏览 器 中 输入 地 址 
Ea 
http://127. 0. 0. 1:8080/tz/denglu. jsp 就 可 以 看 
到 运行 结果 了 (如 图 4-24 一 图 4-32 所 示 ) 。 图 4-24 学 生 登录 
这 是 学 生 登 录 页 面 ! 
这 是 学 生 登 录 页 面 ! 登录 失败 ! 1 BE 
返回 登录 首页 返回 登录 首页 


图 4-25 ”学生 登录 失败 图 4-26 学生 登录 成 功 
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ssPEDER, 当前 时 间 :2014-8-18 17:15:09 CRE) 
测 x 
1、 字 符 串 连接 符号 是 《 ) 
© At © Be O Oag © D)- 
2. CO 用 来 设置 整个 JSP 页 面 的 相关 属性 及 功能 
© page 指令 © B)include 指 令 O C)taglib 指 令 O D) 以 上 都 是 
3、JSP 页 面 能 够 通过 〔 ) 来 包含 其 他 JSP 文 件 、HDIL 文 件 或 文本 文件 
© A)pageti> © B)include 指 令 © Otaglib 指 令 O 四 以 上 都 是 
4、 搭 建 JSP 环 境 需要 下 面 选 项 中 的 哪些 〔〈 ) 
E] A)Tomcat5. 5/Tomcat6.0 口 B)JDK1. 6 口 C)Dreammweaver o 了 ) 浏 览 器 
CEE) CE) 本 次 测验 结果 2 分 


图 4-27 学生 已 登录 
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E B: ^ | 这 是 教师 登录 页 面 ! 
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图 4-28 教师 登录 图 4-29 教师 登录 失败 图 4-30 教师 登录 成 功 
sun 老 师 已 登录 ， 当前 时 间 :2014-8-18 17:18:58 
授课 教师 日 期 
授课 班级 课时 
授课 内 容 su 老师 已 登录 ， 当前 时 间 :2014-8-18 17:20:18 
RF 
授课 教师 GA 日 其 2014-9-2 
授课 班级 15 网 络 两 年 制 “| 课时 2 课时 
授课 内 容 | 综合 训练 


安全 退出 
图 4-31 教师 登录 后 ,编辑 教案 图 4-32 教案 提交 成 功 


Project5 --------------------------------------------------------------- n 


【学 习 目标 】 
了 解数 据 库 的 基本 概念 。 
2. 掌握 SQL 语句 。 
3. 掌握 JDBC-ODBC 技术 。 
4. 能 够 使 用 JDBC-ODBC 技术 访问 数据 库 。 


5.1 SQL 数据 库 的 安装 


511 SQL Server 200 的 安装 


(1) 运行 SQL Server 2000 的 安装 程序 ,弹出 如 图 5-1 所 示 的 安装 界面 , 单 击 “ 安 装 
SQL Server 2000 简体 中 文 个 人 版 ”选项 ,弹出 如 图 5-2 所 示 的 对 话 框 , 单 击 “ 安 装 SQL 
Server 2000 组 件 ” 选 项 ,弹出 如 图 5-3 所 示 的 对 话 框 , 单 击 “ 安 装 数据 库 服 务 器 ”选项 , 弹 
出 如 图 5-4 所 示 的 欢迎 对 话 框 。 


Server 个 人 ES) EE sa Server 2000 iie O 


ES) su Server 2000 ARSE ILA) ERD sua Server 


«p sso 


2000 RSPCA D 


图 5-1 安装 界面 1 


JD He sa server 2000 gft © Q seus o) 
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g 访问 我 们 的 Web 站 点 C 


图 5-2 安装 界面 2 


J 安装 数据 库 服务 器 (5) 
9 安装 Analysis Service (A) 


2 安装 English Query (Q) 
E—2 (B 


SQL Server 2000 能 为 具有 伸缩 性 的 数据 库 
解决 方案 提供 丰富 可 靠 的 支持 。 


图 5-3 安装 界面 3 


(2) 在 欢迎 对 话 框 单 击 "下 一 步 ”, 弹 出 如 图 5-5 所 示 的 计算 机 名 对 话 框 ,这 个 对 话 杠 
主要 是 用 来 设置 创建 SQL Server 的 计算 机 名 称 ,在 这 里 采用 默认 设置 , 单 击 " 下 一 步 ”, 弹 
出 “安装 选择 "对 话 框 ,如 图 5-6 所 示 。 

(3) “安装 选择 "对话 框 主要 供用 户 选 择 安装 的 方式 ,在 这 里 采用 默认 设置 , 单 击 “ 下 
一 步 "进入 “用户 信息 ”对 话 框 ,如 图 5-7 BR. 


we 欢迎 使 用 Microsoft SQL Server 安装 向 导 。 


quasi SQL Server 的 新 实例 或 修改 现 有 的 实 


图 5-4 “欢迎 ”对 话 框 


和 输入 要 在 其 上 外 陡 新 的 SQL Server 实例 或 修改 现 有 
SOL Server 实例 的 计算 机 的 名 称 。 


mo 
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图 5-5 “计算 机 名 ”对 话 框 
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图 5-6 “安装 选择 "对 话 框 


—» | 
5-7 “用 户 信息 ”对话 框 


(4)“ 用 户 信息 ” 对 话 框 主要 用 于 用 户 输入 自己 的 信息 ,输入 完毕 单 击 “ 下 一 步 ”, 进 入 
“安装 定义 ”对 话 框 ,这 个 对 话 框 主要 用 于 供用 户 选 择 安装 类 型 ,在 这 里 选择 “服务 器 和 客 
户 端 工具 ”选项 ,如 图 5-8 所 示 , 单 击 “ 下 一 步 ”, 进 入 “实例 名 ”对 话 框 ,如 图 5-9 所 示 。 
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想 建立 具有 管理 功能 的 服务 器 ， 请 使 用 该 选项 
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图 5-8 “安装 定义 ”对 话 框 


(5) 在 “实例 名 ”对 话 框 中 ,用 户 可 以 选择 安装 或 维护 的 SQL Server 命名 实例 ,在 这 
里 采用 默认 设置 , 单 击 “ 下 一 步 ” 进 入 “安装 类 型 "对 话 框 ,如 图 5-10 所 示 。 

(6)“ 安 装 类 型 "对 话 框 中 有 3 种 安装 类 型 供用 户 选择 : 典型 .最 小 和 自 定义 ,还 可 以 
自 定义 程序 文件 和 数据 库 文件 的 安装 路 径 , 在 这 里 采用 默认 设置 , 单 击 “ 下 一 步 ” 进 入 “ 服 
务 账 户 ” 对 话 框 ,如 图 5-11 所 示 。 

(7)“ 服 务 账户 ?对 话 框 主要 用 于 设置 服务 设置 ,在 这 里 采用 默认 设置 ,然后 中 服务 设置 
中 选择 “使 用 本 地 系统 账户 ”, 单 击 “ 下 一 步 ” 进 入 “身份 验证 模式 ”对 话 框 ,如 图 5-12 所 示 。 

(8)“ 身 份 验证 模式 ”对 话 框 主要 用 于 设置 SQL Server 2000 的 登录 ,在 这 里 采用 默认 
设置 , 单 击 “ 下 一 步 ”, 直 到 最 后 程序 安装 完毕 。 
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若 要 在 该 计算 机 上 安装 或 维护 SQL Server 的 命 
^ 请 请 除 BU SORTIERT 


新 名 称 必须 不 超过 16 个 字符 ,并且 应 以 字母 或 
EEE 有 关 更 多 信息 ， 请 单 击 ” 


图 5-9 “实例 名 ”对 话 框 


安装 最 常用 的 选项 。 建 议 一 般 用 户 采 用 此 种 安装 。 
只 安装 必需 的 选项 。 
C BELO ”您 可 以 选择 要 安装 的 选项 。 建 议 高 级 用 户 采 用 此 种 安装 。 
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图 5-10 “安装 类 型 "对 话 框 


G 对 每 个 服务 使 用 同一 账户 。 自 动 启动 SQL Server RG QD. 
C 自 定义 每 个 服务 的 设置 O. 

服务 设置 
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图 5-11 “服务 账户 ?对 话 框 
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图 5-12 身份 验证 


51.2 SQL Server 2000 AY 45 FA 


(1) 启动 SQL Server 
开始 菜单 选择 “程序 ”一 “M 
管理 器 ,使 用 默认 的 服务 器 


血 各 章节 合并 , do 


4 2003 
fioi tar onc 
[ weciivse 6.0.1 


所 有 程序 (P) D 


€ 360 安 全 中 心 


ISl Outlook Express 


服务 管理 器 。 单 击 Windows 桌面 任务 栏 中 的 “开始 ”按钮 ,在 
icrosoft SQL Server” 一 “服务 管理 器 ”, 如 图 5-13 所 示 , 打 开 服 务 
和 服务 , 单 击 “ 开 始 / 继 续 ” 按 钮 ,如 图 5-14 表示 服务 器 正在 运行 。 
A Windows Update e m 


€ 设 定 程序 访问 和 默认 值 @ Samsung 
R BHM ea EHRE e ni x 


@ Internet Explorer 
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图 5-13 启动 服务 管理 器 
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图 5-14 ”从 “程序 "启动 服务 管理 器 


(2) 启动 SQL Server 企业 管理 器 。 单 击 Windows 桌面 任务 栏 中 的 “开始 ”按钮 ,在 
开始 菜单 选择 “程序 ”一 “Microsoft SQL Server” 一 “企业 管理 器 ”, 如 图 5-15 所 示 , 打 开 企 
业 管 理 器 如 图 5-16 所 示 , 该 工具 提供 了 图 形 化 用 户 界面 ,以 方便 用 户 进行 各 种 数据 库 操作 。 
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图 5-15 企业 管理 器 


(3) 备份 数据 库 。 当 我 们 为 工程 新 建 了 一 个 数据 库 并 且 想 要 把 数据 库 保存 在 该 工程 
的 文件 夹 中 的 时 候 ,就 需要 使 用 数据 库 的 备份 功能 。 首 先 在 需要 备份 的 数据 库 上 单 击 鼠 
标 右键 ,弹出 快捷 菜单 选择 “所 有 任务 ”一 “备份 数据 库 ”, 如 图 5-17 所 示 , 弹 出 备份 对 话 框 
如 图 5-18 所 示 ,数据 库 名 默认 ,备份 选项 选择 数据库 一 完全 ”, 然 后 单 击 * 添 加 ”按钮 打开 
“选择 备份 目的 ?对话 框 如 图 5-19 所 示 。 
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图 5-16 企业 管理 器 图 5-17 备份 数据 库 


选择 备份 目的 


选择 备份 或 备份 设备 。 可 为 经 党 
C SANLAR 


C 文件 名 加 


© 追加 到 媒体 加 
C ESSE C 备份 设备 加: 


r agu: | | 
确定 取消 Li 


图 5-18 "SQL Server 备份 ”对话 框 图 5-19 “选择 备份 目的 "对话 框 


在 “选择 备份 目的 "对话 框 中 ,选择 “文件 名 ”选项 ,并 单 击 …” 按 钮 ,弹出 “备份 设备 位 
置 ?对 话 框 , 如 图 5-20 所 示 , 选 定好 想 要 保存 数据 库 的 位 置 ,并 给 数据 库 起 好 文件 名 ,一 般 
我 们 使 用 数据 库 本 来 的 名 字 命名 ,如 图 5-20 所 示 , 最 后 单 击 “ 确 定 ” 按 钮 完成 数据 库 的 备 
份 ,弹出 完成 对 话 框 如 图 5-21 所 示 。 
(4) 还 原 数据 库 , 这 个 功能 也 是 我 们 后 面 经 常会 用 到 的 , 当 想 要 把 外 部 数据 库 复制 到 
企业 管理 器 中 进行 操作 时 ,还 原 数据 库 这 个 功能 就 可 以 完成 这 项 操作 了 。 首 先 需要 新 建 
一 个 与 要 还 原 的 数据 库 名 称 一 样 的 空 数据 库 , 然 后 在 这 个 空 的 数据 库 上 单 击 鼠 标 右键 , 弹 
出 快捷 菜单 ,选择 “所 有 任务 ”一 “还 原 数 据 库 ”, 如 图 5-22 所 示 , 弹 出 “还原 数 据 库 ” 对 话 框 
如 图 5-23 所 示 ,数据 库 名 已 默认 ,还 原 项 上 选择 “从 设备 "选项 ,备份 选项 选择 “数据 库 一 
完全 ”, 然 后 单 击 “ 选 择 设备 ”按钮 打开 “选择 还 原 设备 ”对 话 框 如 图 5-24 所 示 。 
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图 5-20 “备份 设备 位 置 "对 话 框 
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图 5-21 “备份 完成 "对话 框 图 5-22 还 原 数 据 库 
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A 5-23 “还 原 数 据 库 ” 对 话 框 
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图 5-24 “选择 还 原 设备 "对 话 框 


在 “选择 还 原 设备 ”对 话 框 上 单 击 “ 添 加 ”按钮 ,弹出 “选择 还 原 目的 ”对 话 框 如 图 5-25 
所 示 , 在 这 个 对 话 框 中 单 击 *…” 按 钮 ,弹出 “备份 设备 位 置 " 对 话 框 ,如 图 5-26 所 示 , 选 择 
要 还 原 的 数据 库 , 然 后 单 击 “ 确 定 ” 按 钮 ,直到 最 后 完成 还 原 ,如 图 5-27 所 示 。 


备份 设备 位 置 — (local) 


选择 还 原 掀 作 要 使 用 的 文件 名 或 备份 设备 。 可 为 经 党 
SJ 使用 的 文件 他 建 备 份 设备 。 
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图 5-25 “选择 还 原 目的 ”对话 框 图 5-26 “备份 设备 位 置 " 对 话 框 


SQL Server 企业 管理 器 x 


d) 数据 库 “denslu ”的 还 原 已 顺利 完成 。 


图 5-27 “还 原 成 功 ” 对 话 框 


5.2 使 用 JDBC 一 ODBC 技术 连接 数据 库 


实战 演练 一 一 用 户 的 注册 登录 
【题目 】 


题目 要 求 使 用 数据 库 技术 ,新建 数据 库 名 称 为 denglu, 会 员 表 为 customer。 完 成 的 
功能 为 ,用 户 能 够 在 登录 界面 注册 成 为 网 站 的 会 员 ,并 且 能 够 作为 会 员 登 录 网 站 。 


【分 析 】 
要 完成 本 题目 需要 先 理 清 思路 一 步 一 步 地 完成 ,步骤 如 下 。 
(1) 本 题 要 完成 的 功能 模块 如 图 5-28 所 示 。 


(2) 打开 SQL 软件 的 企业 管理 器 ,新 建 数据 库 denglu, 如 图 5-29 和 图 5-30 所 示 。 
(3) 在 denglu 数据 库 中 新 建 会 员 用 户 表 customer, 表 的 设计 情况 如 图 5-31 所 示 。 
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图 5-28 登录 注册 模块 图 5-29 新 建 数据 库 


(未知) 


5-30 新建 数据 库 denglu 图 5-31 customer X 


(4) 建立 ODBC 数据 源 ,打开 系统 管理 工具 一 一 ODBC 数据 源 管 理 器 对 话 框 , 单 击 
“添加 ”按钮 (如 图 5-32 和 图 5-33 所 示 ) ,弹出 新 建新 数据 源 对 话 框 (如 图 5-34 所 示 ) ,选择 


最 后 一 项 SQL Server, 然 后 单 击 “ 完 成 ”按钮 。 


然后 弹出 “创建 到 SQL Server 的 新 数据 源 ” 对 话 框 (如 图 5-35 所 示 ) ,数据 源 名 称 命 
名 为 数据 库 的 名 称 denglu, 服 务 器 项 选择 本 地 服务 器 的 名 称 。 单 击 “ 下 一 步 ? 弹 出 对 话 框 
(如 图 5-36 Pras) ,再 单 击 * 下 一 步 ? 弹 出 对 话 框 (如 图 5-37 所 示 ) ,选择 默认 数据 库 为 denglu。 
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图 5-32 控制 面板 一 一 管理 工具 


“ODBC 数据 源 管 理 器 
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图 5-33 “ODBC 数据 源 管 理 器 "对 话 框 


创建 新 数据 源 


选择 您 起 为 其 安装 数据 源 的 3E 动 程序 G)。 


名 称 


Microsoft Excel-Treiber (xls) 
Microsoft ODBC for Oracle 


Microsoft Paradox Driver (#. db ) 
Microsoft Paradox-Treiber (*.db ) 
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图 5-34 创建 SQL 新 数据 源 
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图 5-35 ”数据 源 名 称 denglu 


创建 到 SQL Server 的 新 数据 源 
SQL Server 应 该 如 何 验证 登录 ID 的 真 伪 ? 
C BARAER DAT ETU. 


C 使 用 用 户 输 入 登录 ID 和 密码 的 SQL Server WE C). 
要 更 改 用 于 与 SQL Server 通讯 的 网 络 库 ， 请 单 击 “ 客 户 端 配置 ” 


. SPERO —— | 


Jv 连接 SQL Server 以 获得 其它 配置 选项 的 默认 设置 C)。 


= 


图 5-36 SQL Server 验证 


创建 到 SQL Server 的 新 数据 源 


M 更 改 默认 的 数据 库 为 四 ) 
[em 

厂 附加 数据 库 文件 名 QD: 
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图 5-37 选择 默认 数据 库 denglu 


Q (mamme weise] 000 0T 


然后 再 单 击 “下 一 步 ”, 弹 出 对 话 框 ( 如 图 5-38 所 示 ) ,最 后 单 击 “ 完 成 ?按钮 就 可 以 看 
到 已 经 添加 好 的 数据 源 了 (如 图 5-39 所 示 ) 。 


创建 到 SQL Server 的 新 数据 源 


Ll 
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厂 将 长 时 间 运 行 的 查询 保存 到 日 志文 件 G): 
F 


Ka xe WO: [oo 
厂 将 onee 3 动 程序 统计 记录 到 日 志文 件 o) 
I: 


«r-5g[ ar ] mx | am | 


图 5-38 新 数据 源 设 置 


“ODBC 数据 源 管理 器 
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图 5-39 denglu 数据 源 成 功 添加 


(5) 题目 中 需要 的 代码 文件 有 : mydb. java 完成 保存 连接 数据 库 的 代码 和 用 于 对 数 
据 库 进行 增删 改 查 以 及 汉字 识别 的 方法 ; denglu. html 完成 登录 界面 的 设计 ; denglu. jsp 
完成 查找 数据 库 中 的 customer 表 中 的 会 员 信 息 ; ze. html 完成 会 员 注 册 的 界面 设计 ; ze 
1.jsp 完成 会 员 信息 添加 到 数据 库 的 customer 表 ; success. jsp 完成 登录 成 功 信息 的 显示 。 
【运行 效果 】 

打开 开发 工具 MyEclipse, 新 建 一 个 工程 jsp-jdbc, 在 src 文件 夹 下 新 建 bean 文件 夹 ， 
在 bean 文件 夹 中 新 建 mydb. java 文件 ; 在 这 个 工程 的 WebRoot 文件 夹 下 ,新 建文 件 
denglu. html ,denglu. jsp.zc. html、zc_1. jsp, success. jsp。 程 序 输入 完毕 并 且 保 存 之 后 ， 
运行 开发 工具 MyEclipse 中 的 Tomcat 服务 器 。 最 后 在 浏览 器 中 输入 地 址 http:// 


127. 0. 0. 1:8080/jsp-jdbc/denglu. html 就 可 以 看 到 运行 结果 了 (如 图 5-40 一 图 5-43 所 示 ) 。 
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图 5-40 登录 界面 denglu. html 
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图 5-41 注册 界面 zc. html 
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图 5-42 会 员 登 录 界 面 denglu. html 
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图 5-43 登录 成 功 success. jsp 
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【 源 代码 】 
[mydb. java] 


package bean; 
import java. sql. * ; 
public class mydb ( 
private Connection conn; 


String message; 


1 

2 

3 

4 

5 private Statement stmt; 
6 

7 public void connection( ) 
8 

9 


{ try 
{ Class. forName( "sun. jdbc. odbc. JdbcOdbcDriver") ; 

10 conn— DriverManager. getConnection( "jdbc:odbc: denglu"); 
11 stmt= conn. createStatement( ) ; } 
12 catch(ClassNotFoundException e) 
13 { message= "connection" +e; } 
14 catch( SQLException e) 
15 { message— "query" +e; } 


16 j 
17 public ResultSet query(String sql) 
18 { ResultSet rs— null; 


19 try 

20 ( rs stmt. executeQuery(sql) ;} 
21 catch( SQLException e) 

22 { message— "query" +e; } 

23 return rs; 

24 ) 


25 public int update(String sql) 
26 (| int n=0; 


27 try 

28 { n-stmt.executeUpdate( sql) ; ) 
29 catch( SQLException e) 

30 { message— "update" +e; } 

31 return n; 

32 ) 


33 public boolean delete(String sql) 
34  ( boolean b false; 


35 try 
36 ( b=stmt. execute(sql) ; } 
37 catch(SQLException e) 

38 { message="delete"+e;} 
39 return b; 

40} 


41 public String hzsb(String s) 
42 { String str=s; 


43 try 
44 {byte b[] =str. getBytes("ISO-8859-1") ; 
45 str=new String(b) ; 


46 return str; } 


47 catch( Exception e) 
48 {return str;) 
49 } 

50 } 


mydb. java 补充 说 明 

第 1 行 ,说 明 mydb. java 是 在 bean 文件 夹 中 的 。 

第 2 行 ,引入 java 的 SQL 包 , 因 为 在 下 面 的 代码 中 有 关于 SQL 数据 库 的 命令 操作 。 

第 3 行 ,声明 一 个 公共 类 ,类 的 名 字 为 mydb ,与 这 个 文件 的 文件 名 相同 ,是 在 文件 生 
成 的 时 候 自动 生成 的 类 名 。 

第 4 行 ,conn 变量 是 公共 类 的 私有 变量 ,用 于 完成 数据 库 连接 。 

第 5 行 ,stmt 是 私有 变量 ,用 于 执行 SQL 命令 。 

第 7 行 到 第 16 行 ,声明 connection() 为 公共 方法 ,完成 对 数据 库 的 连接 。 

第 9 行 ,装载 JDBC 驱动 程序 。 

第 10 行 ,conn 被 赋值 为 连接 数据 库 denglu 的 语句 。 

第 11 行 ,stmt 被 赋值 为 能 够 执行 对 denglu 数据 库 操作 的 对 象 。 

第 17 行 到 第 24 行 ,声明 query() 方 法 是 公共 方法 ,完成 数据 库 的 查询 功能 ,query() 
方法 的 返回 值 类 型 是 ResultSet, 也 就 是 说 返回 值 为 数据 库 里 面 的 记录 集 。 

第 25 行 到 第 32 行 , 声 明 update() 方 法 是 公共 方法 ,完成 的 功能 是 对 数据 库 记 录 的 更 
新 ,返回 值 是 int 型 ,如 果 返 回 值 为 1 则 说 明 更 新 数据 库 成 功 , 如 果 不 为 1 就 说 明 更 新 
失败 。 

第 33 行 到 第 40 行 , 声 明 delete() 方 法 是 公共 方法 ,完成 的 功能 是 对 数据 库 记 录 的 删 
除 , 返 回 值 是 布尔 型 。 

第 41 行 到 第 49 行 , 声 明 hzsb() 方 法 是 公共 方法 ,完成 的 功能 是 汉字 识别 ,返回 值 是 


字符 串 类 型 。 
【 源 代码 】 
[denglu. htm!) 
1 <html> 
2 <head> 
3 <title> ER HK i </title> 
4 <style type="text/css"> 
5 <!-- 
6 .STYLE9 (font-family: Arial, Helvetica, sans-serif; font-size: 18px; } 
T --> 
8 </style> 
9 </head> 
10 <body> 
11 <form id="form5" name= "form5" method="post" action= "denglu.jsp"— 
12 <table width="500" border— "0" align="center" cellpadding="0" cellspacing="2" 
bgcolor=" # 0099CC"> 
13 <u> 


14 <td width— "203" align="right" valign="middle" bgcolor=" # FFFFFF"> 
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<span class= "STYLE9" J P1 4 : </span></td> 


15 <td width= " 394" height ="50" valign="middle" bgcolor =" # FFFFFF" > 
& nbsp; & nbsp; & nbsp; & nbsp; & nbsp; 

16 <input name="username" type="text" id— "textfield" size="15" /></td> 

17 </tr> 

18 <tr> 

19 <td align="right" valign="middle" bgcolor =" # FFFFFF" >< span class = 
"STYLE9"> #5: </span> </td> 

20 <td height ="50" valign="middle" bgcolor =" # FFFFFF" > &nbsp; &-nbsp; 
& nbsp; &-nbsp; &-nbsp; 

21 <input name= "password" type="password" id= "textfield2" size="15" /> 
</td> 

22 </tr> 

23 <tr> 

24 <td height="50" colspan— "2" align="center" valign— "middle"bgcolor— " # FFFFFF"> 

25 <input type="submit" name="button" id="button" value=" #3" /> 

26 & nbsp; &-nbsp; & nbsp; 

27 <input type= "reset" name="button2" id— "button2" value=" 取 消 " /></td> 

28 </tr> 

29 <u> 

30 <td height="50" colspan="2" align="center" valign="middle" 
bgcolor=" # FFFFFF" class= "STYLE9" ><a href= "zc. html" iE lE — / a7 — / td 

31 </tr> 

32 </table> 

33 </form> 

34 </body> 

35 </html> 

denglu. html 补充 说 明 


第 4 行 到 第 8 行 , 设 置 整个 界面 的 字体 格式 。 
第 11 行 到 第 33 行 ,是 一 个 form 表单 ,表单 的 数据 将 提交 到 denglu. jsp 文件 。 
第 12 行 到 第 32 行 ,是 一 个 表格 ; 第 13 到 第 17 行 ,是 表格 第 一 行 ,其 中 第 二 个 单元 
格 中 放置 了 一 个 文本 框 , 用 于 输入 用 户 名 ,变量 名 定 为 username; 第 18 到 第 22 行 ,是 表 
格 第 二 行 ,其 中 第 二 个 单元 格 中 放置 了 一 个 密码 框 , 用 于 输入 登录 密码 ,变量 名 定 为 
password; 第 23 行 到 第 28 行 , 是 表格 的 第 三 行 ,其 中 放置 了 按钮 ,一 个 用 于 提交 表单 信 
息 , 一 个 用 于 重新 输入 ; 第 29 行 到 第 31 行 ,是 表格 第 四 行 ,单元 格 中 设计 了 一 个 用 户 注 
册 的 链接 ,链接 到 zc. html 文件 。 
【 源 代码 】 
【denglu. jsp] 
1 <%@ page contentType="text/html; charset—gb2312" language="java" import="java. sql. * "%> 
2 <html> 
3 <body> 
<jsp:useBean id="db" class— "bean. mydb" scope="page"/> 
<% 
String username= db. hzsb( request. getParameter( "username" ) ) ; 


ane 


uL NEEDED [ 情境 五 J5P 数 据 库 必用 KON 


7 String password= request. getParameter( "password" ) ; 
8 db. connection() ; 
9 ResultSet rs=null; 
10 rs=db.query("SELECT * FROM customer WHERE id="+"\'"-+username+"\'"+ " 
AND password="-++"\'"-++password+"\'"") ; 
11 while(rs. next()) 
12 { 
13 session. setAttribute( "username", username) ; 
14 response. sendRedirect("success. jsp"); 
15 } 
16 $> 
17 </body> 
18 </html> 
denglu. jsp 补充 说 明 


第 1 行 ,引入 Java 类 的 SQL 包 , 因 为 下 面 代码 用 到 了 SQL 命令 。 

第 4 行 ,使 用 useBean 动作 ,使 用 的 类 是 bean 文件 夹 下 的 mydb 类 ,类 的 对 象 为 db 。 

第 6 行 ,新 建 字符 串 型 变量 username 接收 denglu. html 文件 传递 过 来 的 用 户 名 ,并 
且 使 用 db 对 象 调 用 hzsb() 方 法 ,以 防 用 户 输入 汉字 产生 乱码 。 

第 7 行 ,新 建 字符 串 型 变量 password 接收 denglu. html 文件 传递 过 来 的 密码 。 

第 8 行 ,使 用 db 对 象 调用 connection() 方 法 ,连接 数据 库 。 

第 9 行 ,声明 rs 为 记录 集 型 的 变量 。 

第 10 行 ,db 对 象 调 用 query() 方 法 查找 数据 库 的 customer 表 , 看 前 面 接收 的 用 户 名 
和 密码 是 否 与 表 中 的 符合 ,并 把 query() 方 法 的 返回 值 赋 给 rs。 

第 11 行 到 第 15 行 , 当 rs 中 有 符合 上 面 查 找 条 件 的 记录 集 时 ,使 用 session 方法 把 用 
户 登 录 时 输入 的 用 户 名 赋值 给 username 变量 ,然后 使 用 response 方法 直接 把 链接 地 址 
定向 到 登录 成 功 页 面 success. jsp。 


【 源 代码 】 
【zc. html) 
1 <html> 
2 <head> 
3 <title>2 AEM </title> 
4 <style type="text/css"> 
5 <l-- 
6 .STYLE1 { font-family: "华文 新 魏 "; font-size: 24px; color: # FF9900; } 
7 .STYLE4 (font-family: "宋体 "; font-size: 18px; } 
8 --> 
9 </style> 
10 </head> 
11 <body> 
12 <form id="forml" name="form1" method="post" action="zc_1.jsp"> 
13 <table width 一 "400" border— "0" align — " center" cellpadding — "0" cellspacing="2" 
bgcolor=" # CCCCCC"— 
14 xu 


15 < td height — " 40" colspan — "2" align =" center" valign =" middle" bgcolor = 
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16 
17 
18 


19 
20 
21 
22 
23 


24 
25 
26 
27 
28 


29 
30 
31 
32 
33 


34 
35 
36 
37 
38 


39 
40 
Al 
42 
43 
44 
45 
46 


47 
48 
49 
50 
51 


52 
53 
54 
55 
56 


" # FFFFFF" ><span class= "STYLE" JH PE Mt </span> </td> 
</tr> 
<u> 
<td width="40%" height="30" align="center" bgcolor=" # FFFFFF" ><span 
class= "STYLEA" H] P! 4 : </span></td> 
<td height="30" align="left" bgcolor=" # FFFFFF"> 
<input type="text" name= "username" id="textfield" /></td> 
</tr> 
<tr> 
<td height — "30" align =" center" bgcolor =" # FFFFFF" > < span class = 
"STYLE4"> #5: </span> </td> 
<td height="30" align="left" bgcolor=" # FFFFFF"> 
<input type="text" name= "password" id— "textfield2" /></td> 
</tr> 
<tr> 
<td height =" 30" align="center" bgcolor =" # FFFFFF" > < span class = 
"STYLEA" > MUE: </span> </td> 
<td height="30" align="left" bgcolor=" # FFFFFF"> 
<input type="text" name= "confirmpassword" id— "textfield3" /></td> 
</tr> 
<tr> 
<td height =" 30" align="center" bgcolor =" # FFFFFF" > < span class = 
"STYLE4" >t 4% : </span></td> 
<td height="30" align="left" bgcolor=" # FFFFFF"> 
<input type="text" name="name" id="textfield4" /></td> 
</tr> 
<tr> 
<td height — "30" align="center" bgcolor =" # FFFFFF" > < span class = 
"STYLE4">t# 4: </span> </td> 
<td height="30" align="left" bgcolor=" # FFFFFF"> 
<select name— "sex" id=" select" > 
<option> 9j </option> 
<option>&</option> 
</select></td> 
</tr> 
<tr> 
<td height —"30" align="center" bgcolor =" # FFFFFF" >< span class = 
"STYLE4" 之 地 址 : </span></td> 
<td height="30" align="left" bgcolor=" # FFFFFF"> 
<input type="text" name— "address" id="textfield6" /></td> 
</tr> 
<tr> 
<td height — "30" align="center" bgcolor =" # FFFFFF" >< span class = 
"STYLE4"> th 4: </span> </td> 
<td height="30" align="left" bgcolor=" # FFFFFF"> 
<input type="text" name="code" id= "textfield7" /></td> 
</tr> 
<u> 
<td height — "30" align="center" bgcolor =" € FFFFFF" > < span class = 


"STYLE4"> fi: </span></td> 


57 <td height="30" align="left" bgcolor=" # FFFFFF"> 
58 <input type="text" name="tel" id="textfield8" /></td> 
59 </tr> 
60 xu 
61 <td height — " 30" align="center" bgcolor =" # FFFFFF" >< span class = 
"STYLE4">e-mail: </span></td> 
62 <td height="30" align="left" bgcolor=" # FFFFFF"> 
63 <input type="text" name="email" id="textfield9" /></td> 
64 </tr> 
65 <tr> 
66 <td height ="30" colspan="2" align="center" valign="middle" bgcolor = 
" # FFFFFF"> 
67 < input type="submit" name =" button" id —" button" value =" mM" /> 
&-nbsp; & nbsp; & nbsp; &-nbsp; 
68 <input type— "reset" name="button2" id="button2" value 一 " 重 填 " /></td> 
69 </tr> 
70 </table> 
7" </form> 
72 </body> 
73 </html> 
zc. html 补充 说 明 


第 4 行 到 第 9 行 ,设置 界面 的 字体 格式 设置 。 

第 12 到 第 71 行 , 是 一 个 表单 ,表单 的 数据 将 提交 到 zc_1. jsp 文件 。 

第 13 到 第 70 行 ,是 一 个 表格 ; 第 14 行 到 第 16 行 是 表格 的 第 一 行 ; 第 17 行 到 第 
21 行 ,是 表格 的 第 二 行 , 在 这 行 的 第 二 个 格 里 有 一 个 文本 框 , 用 于 输入 注册 的 用 户 名 , 变 
量 名 为 username; 第 22 行 到 第 26 行 ,是 表格 的 第 三 行 ,在 这 行 的 第 二 个 格 里 有 一 个 文本 
框 ,用 于 输入 注册 密码 ,变量 名 为 password; 第 27 行 到 第 31 行 , 是 表格 的 第 四 行 , 在 这 行 
的 第 二 个 格 里 有 一 个 文本 框 ,用 于 再 次 输入 注册 的 密码 ,变量 名 为 confirmpassword; 第 
32 行 到 第 36 行 , 是 表格 的 第 五 行 , 在 这 行 的 第 二 个 格 里 有 一 个 文本 框 ,用 于 输入 用 户 真 
实 姓名 ,变量 名 为 name; 第 37 行 到 第 44 行 , 是 表格 的 第 六 行 ,在 这 行 的 第 二 个 格 里 有 一 
个 下 拉 列 表 , 下 拉 列 表 有 两 个 选项 ,变量 名 为 sex, 用 于 选择 注册 用 户 的 性 别 ; 第 45 行 到 
第 49 行 ,是 表格 的 第 七 行 , 在 这 行 的 第 二 个 格 里 有 一 个 文本 框 , 用 于 输入 用 户 住址 ,变量 
名 为 address; 第 50 行 到 第 54 行 表 格 的 第 八 行 ,在 这 行 的 第 二 个 格 里 有 一 个 文本 框 ,用 
于 输入 用 户 邮 编 , 变 量 名 为 code; 第 55 行 到 第 59 行 表格 的 第 九 行 ,在 这 行 的 第 二 个 格 里 
有 一 个 文本 框 , 用 于 输入 用 户 电 话 , 变 量 名 为 tel: 第 60 行 到 第 64 行 表格 的 第 十 行 ,在 这 
行 的 第 二 个 格 里 有 一 个 文本 框 , 用 于 输入 用 户 邮件 ,变量 名 为 email; 第 65 行 到 第 69 fT 
表格 的 第 十 一 行 ,在 这 行 里 放置 两 个 按钮 ,一 个 用 于 提交 表单 的 所 有 数据 ,一 个 用 于 重新 
填写 表单 内 容 。 
【 源 代码 】 
【zc_1.jsp】 


1 <%@ page contentType="text/html; charset 一 gb2312" language="java" import="java. sql. * "%> 
2 <html> 
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3 <body> 

4 <jsp:useBean id— "db" class— "bean. mydb" scope="page"/> 

5 <% 

6 String id=db. hzsb( request. getParameter( "username" )) ; 

7 String password= db. hzsb( request. getParameter(" password") ) ; 

8 String name= db. hzsb( request. getParameter("name")) ; 

9 String sex— db. hzsb(request. getParameter( "sex")) ; 

10 String address— db. hzsb(request. getParameter( "address" ) ) ; 

11 String code= db. hzsb( request. getParameter("code")) ; 

12 String tel— db. hzsb(request. getParameter("tel")) ; 

13 String email— db. hzsb( request. getParameter( "email")) ; 

14 if (id! —null &-& password! —null && name! — null && sex! —null && 
address! =null&.&. code! — null && tel! —null && email! —null) 

15 { String rssql =" insert into customer values (" +"\'" id +"\'"+"," + "\ "十 


password "V "E", " JV" Ename-- V E", " EV Esex-E Vp tpe e 
address-- "V" 4-" ," - "V" --code-- "V" 4e", "EV tel" "+", 4) email 


rtp; 
16 db. connection() ; 
17 int rsn— db. update(rssql) ; 
18 if (rsn>0) 
19 response. sendRedirect(" denglu. html") ; 
20 }%> 
21 </body> 
22 </html> 
zc_1.jsp 补充 说 明 


第 1 行 ,引入 java 类 的 SQL 包 , 因 为 下 面 代 码 用 到 了 SQL 命令 。 

第 4 行 ,使 用 useBean 动作 ,使 用 的 类 是 bean 文件 夹 下 的 mydb 类 ,类 的 对 象 为 db. 

第 6 行 到 第 13 行 , 接 收 zc. html 文件 传递 过 来 的 各 项 注册 信息 ,并且 使 用 db 对 象 调 
用 hzsb() 方 法 ,以 防 用 户 输入 汉字 产生 乱码 。 

第 14 行 到 第 20 行 ,是 一 组 让 语句 , 当 所 有 注册 信息 都 不 为 空 的 时 候 执行 这 语句 中 的 
所 有 操作 。 

第 15 行 ,声明 一 个 字符 串 型 变量 rssql, 赋 值 为 SQL 插入 语法 的 句子 。 

第 16 行 ,使 用 db 对 象 调用 connection() 方 法 连接 数据 库 。 

第 17 行 ,使 用 db 对 象 调用 update() 方 法 执行 对 customer 表 的 记录 插入 ,并 把 返回 
值 赋 给 整形 变量 rsn。 

第 18 行 到 第 19 行 ,是 一 组 让 语句 ,如 果 rsn 的 返回 值 大 于 0, 就 表示 上 一 句 的 记录 插 
入 成功, 那么 就 可 以 直接 跳 转 到 denglu. html 界面 ,进行 登录 了 。 
【 源 代码 】 
【success. jsp] 

1 <%@ page contentType— "text/html; charset=gb2312" language— "java" %> 


2 <html> 
3 <head> 


4 <title> ER JJ] — / title 

5 </head> 

6 <body> 

7 欢迎 & nbsp; &nbsp;< % = session. getAttribute( " username") % > & nbsp; & nbsp; # $ 
8 </body> 

9 </html> 


521 JDBC 技 术 和 驱动 程序 


JDBC(Java DataBase Connectivity) 可 以 说 是 Java 应 用 程序 与 数据 库 的 沟通 桥梁 。 
通过 JDBC 提供 的 API( 应 用 程序 接口 ) 进 行程 序 设 计时 ,可 以 轻松 地 编写 出 和 数据 库 连 
接 的 应 用 程序 。 

522 Jsp 中 使 用 B80 一 0080 访 问 数据 库 


JDBC-ODBC 驱动 程序 是 JDBC 连接 数据 的 方法 之 一 ,该 驱动 程序 首先 将 JDBC 数据 
转换 成 ODBC 数据 源 , 然 后 再 利用 ODBC 与 数据 库 进行 连接 。 
1k JSP 中 使 用 JDBC 一 ODBC 访问 数据 库 一 般 来 说 有 下 列 几 个 步骤 。 


l. 装载 数据 库 的 JDBC 驱动 程序 


装载 数据 库 系 统 的 驱动 程序 ,是 将 JDBC 驱动 程序 的 类 载 入 到 Java 虚拟 机 中 ,需要 
java. lang. class 类 中 的 Class. forName() 方 法 来 实现 。 
语法 格式 : 


Class. forName( driver name ); 


上 面 例题 中 的 用 法 : 


Class.forName("sun.jdbc.odbc.JdbcOdbcDriver") ; 


2. 与 数据 库 建立 连接 


Connection 是 用 来 表示 数据 库 连 接 的 对 象 , 对 数据 库 的 一 切 操作 都 是 在 这 个 连接 的 
基础 上 进行 的 。 
语法 格式 : 


Connection con= DriverManager. getConnection(url, username, password) 
上 面 例题 中 的 用 法 : 

conn= DriverManager. getConnection("jdbc:odbc:shici") ; 

3. 将 SQL 语 身 传递 到 数据 库 中 ,执行 操作 ,返回 得 到 的 结果 


Statement 对 象 是 一 个 接口 的 定义 ,其 中 包括 了 执行 SQL 语句 和 获取 返回 结果 的 方 
法 。Statement 对 象 用 于 执行 不 带 参数 的 简单 SQL 语句 。 
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语法 格式 : 
Statement stmt = con. createStatement() ; 
上 面 例题 中 的 用 法 : 
stmt= conn. createStatement() ; 
Statement 接口 提供 了 3 种 执行 SQL 语句 的 方法 。 


(1) executeQuery() 方 法 用 于 产生 单个 结果 集 的 SQL 查询 语句 
上 面 例题 中 的 用 法 : 


ResultSet rs= stmt. executeQuery(sql) ; 


ResultSet 用 来 暂时 存放 数据 库 查询 操作 获得 的 结果 。 它 包含 了 符合 SQL 语句 中 条 件 的 
所 有 行 , 并 提供 了 get 方法 对 这 些 行 中 的 数据 进行 访问 。 

(2) executeUpdate() 方 法 返回 值 是 一 个 整 型 值 

上 面 例题 中 的 用 法 : 


n= stmt. executeUpdate( sql) ; 


(3) execute() 方 法 用 于 执行 返回 多 个 结果 集 或 多 个 更 新 计数 的 语句 ,返回 值 是 布尔 值 
上 面 例题 中 的 用 法 : 


b= stmt. execute(sql) ; 
4, 关闭 数据 库 连 接 


语法 格式 rs. close(); 


5.3 JSP 对 数据 库 的 操作 


实战 演练 全 一 诗词 目录 


【题目 】 

要 求 制作 一 个 诗词 目录 ,能 够 显示 诗词 的 序号 .作者 类别. 题目 ,并 且 能 够 增加 、 修 
改 、 删 除 任意 一 条 目录 ,只 有 诗词 目录 的 序号 不 可 更 改 。 
【分 析 】 

要 完成 本 题目 需要 先 理 清 思路 一 步 一 步 地 完成 ,步骤 如 下 。 

(1) 本 题 要 完成 的 功能 模块 如 图 5-44 所 示 。 


诗词 目录 首页 
I 
i 1 1 
增加 目录 修改 目录 meas] 


图 5-44 功能 模块 
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(2) 打开 SQL 软件 的 企业 管理 器 ,新 建 数据 库 shici, 如 图 5-45 所 示 。 


© $l GRA \Microsoft SQL Serve 
名 控制 台 根 目录 — 
29 licrosoft SQL Servers 名 称 


= @ SL. Server 组 i 

Bb (local) (Windows | Eactpreverties 
2G 数据 库 国 syscolums 

& U bookshop || 回 syscamments 


$ U college 
& B denglu 

S U master 

@ U message 
@ U model 

@ U ned 

& @ Northwind 


国 sysdepends 
Elsysfilesroups 
Elsysfiles 

回 sysfilesl 

回 sysforeignkeys 

回 sysfulltextcataloga 
Elsysfulltextnoti fy 


sysindexes 
Disysindexkeys 
国 sysnenbers 
国 sysobjects 


& B pubs 


5-45 数据 库 shici % mulu 
会 员 用 户 表 mulu, 表 的 设计 情况 如 图 5-46 所 示 。 


i i! 


(3) 在 shici 数据 库 中 新 


Æ 5-46 mulu 表 的 设计 和 说 明 
(4) 建立 ODBC 数据 源 ,打开 系统 管理 工具 一 一 ODBC 数据 源 对 话 框 ,添加 shici Be 
据 源 ,如 图 5-47 所 示 。 


ODBC 数据 源 管 理 器 | 
FAP nsw | 系统 nsu] 文件 usw | BERbE E | 跟踪 | 连接 池 | 关于 | 


id 


用 户 数 据 源 Q0 

名 称 驱动 程序 mo) 
bookshop SQL Server — 
dBASE Files Microsoft dBase Driver (+. 4b) 删除 
denglu SQL Server Heo | 
Excel Files Microsoft Excel Driver (*. xls) 

message SQL Server ERO. 
MS Access Database Microsoft Access Driver (* mdb 

SQL Server 

Visual FoxPro Database Microsoft Visual FoxPro Driver 

Visual FoxPro Tables Microsoft Visual FoxPro Driver 


图 5-47 添加 数据 源 shici 


(5) 题目 中 需要 的 代码 文件 有 : mydb. java 完成 保存 连接 数据 库 的 代码 和 用 于 对 数 
据 库 进行 增删 改 查 以 及 汉字 识别 的 方法 ; shici. jsp 完成 对 数据 库 中 mulu 表 的 读 取 , 并 显 
示 在 界面 上 ,还 要 提供 “添加 ”“ 删 除 ”“ 修 改 ” 的 链接 ; sc add. html 完成 添加 目录 的 界面 
设计 ,并 且 提 交 输 入 的 数据 ; sc_add_1. jsp 完成 对 目录 信息 的 入 库 操作 ; sc. edit. jsp 完成 
需要 修改 的 目录 信息 的 显示 ,并 且 把 修改 后 的 目录 信息 更 新 到 mulu XP; sce del. jsp 完 
成 对 某 条 目录 的 删除 。 
【运行 效果 】 

打开 开发 工具 MyEclipse, 在 工程 jsp-jdbc 中 ,在 bean 文件 夹 中 修改 mydb. java 文 
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ff; 在 这 个 工程 的 WebRoot 文件 夹 下 ,新 建文 件 shici. jsp、sc_add. html,sc_add_1. jsp, 
sc_edit. jsp、sc_del. jsp。 程 序 输 入 完毕 并 且 保 存 之 后 ,运行 开发 工具 MyEclipse 中 的 
Tomcat 服务 器 。 最 后 在 浏览 器 中 输入 地 址 http://127. 0. 0. 1: 8080/jsp-jdbc/shici. jsp. 
就 可 以 看 到 运行 结果 了 (如 图 5-48 ~ FA] 5-52 所 示 )。 


RERE 
EERE 


D 向 数据 库 添加 目录 信 
添加 目录 
要 求 新 添加 的 目录 内 容 序号 不 能 和 已 存在 的 重复 


PE: 


图 5-49 添加 页 面 sc_add. html 


J ose « 


唐诗 宋词 目录 

序号 | 作者 [sw [ma | 

1 (*8 | 唐诗。 Denm | ea |a 
2 Ea mi ssa E [73 
3 (UK mI QU sx am 
4 *ü ime ATAD feck | a 
5 WSR ma Ese | pz | a 

in 3 


图 5-51 添加 成 功 返 回首 页 面 


【 源 代码 】 
[mydb. java] 


1 package bean; 
2 import java.sql. * ; 


口 第 一 个 数据 库 练习 


序号 «Lud 
| 唐诗 
唐诗 


ms 
| gis 
E 


His-52 修改 成 功 返回 首页 面 se_add. jsp 


public class mydb { 
public void connection() { 
try{ 
Class. forName( "sun. jdbc. odbc. JdbcOdbcDriver") ; 
conn= DriverManager. getConnection( "jdbc: odbe: shici" ) ; 


(€ 0 -3 0 0 Sw 


mydb, java 补充 说 明 : 
这 个 文件 和 上 一 个 题目 的 文件 是 一 样 的 ,只 需 将 第 8 行 代码 中 数据 库 的 名 字 改 成 
shici 就 可 以 通用 这 整 篇 代码 了 。 


【 源 代码 】 
[shici. jsp] 
1 <%@page contentType="text/html; charset=gb2312" import="java.sql. * " %> 
2 <html><head><title> 585 — S48 Pe i 2] — title <head> 
3 <body> 
4 <jsp:useBean id= "db" class="bean. mydb" scope="page"/> 
5 <p align="center"> JE PEAK is] H </p> 
6 <table width— "700" cellspacing— "1" cellpadding— "8" border= "O"bgcolor— " # 669966" 
align="center" height="75"> 
7 <tr> 
8 <td bgcolor=" # FFFFFF" width— "1026" &-nbsp; E — /td 
9 <td bgcolor=" # FFFFFF" width 王 "20% "二 作者 &nbsp;</td> 
10 <td bgcolor=" # FFFFFF" width— "1026 "72€ 9| & nbsp; </td> 
11 <td bgcolor=" # FFFFFF" width="40%"> 8 &nbsp;</td> 
12 <td colspan="2" bgcolor=" # FFFFFF" width="20%"> &-nbsp; </td> 
13 </tr> 
14 <% 
15 ResultSet rs=null; 
16 db. connection() ; 
17 String query— "select * from mulu"; 
18 rs— db. query(query) ; 
19 while (rs. next) 
20 ( 


21 String sl— rs. getString(1) ; 


22 String s2— rs. getString(2) ; 

23 String s3=rs. getString(3) ; 

24 String s4— rs. getString(4) ; 

25 n 

26 <u> 

27 <td bgcolor=" # FFFFFF" ><% =s1% ><br></td> 

28 <td bgcolor=" # FFFFFF" ><% — 5294 ><br></td> 

29 <td bgcolor=" # FFFFFF">< % =s3% ><br></td> 

30 <td bgcolor=" # FFFFFF" ><% =s4% ><br></td> 

31 <td bgcolor=" # FFFFFF">&-nbsp;<a href="sc_edit. jsp?id=<%=sl %> "> 
BM</a></td> 

32 <td bgcolor=" # FFFFFF">&-nbsp;<a href="sc_del.jsp?id=<%=sl %> "> 
WI ER</a></td> 

33 </tr> 

34 <% } *> 


35 </table> 

36 <p align="center" ><a href="sc_add.jsp"> #84 

37 </body> 

38 </html> 
shici. jsp 补充 说 明 

第 1 行 ,引入 java 类 的 SQL 包 , 因 为 下 面 代码 用 到 了 SQL 命令 。 

第 4 行 ,使 用 useBean 动作 ,使 用 的 类 是 bean 文件 夹 下 的 mydb 类 ,类 的 对 象 为 db 。 

第 6 行 到 第 35 行 ,是 一 个 表格 ,第 7 行 到 第 13 行 ,是 表格 的 第 一 行 。 

第 15 行 , 声 明 rs 为 记录 集 型 的 变量 。 

第 16 行 , 使 用 db 对 象 调用 connection() 方 法 ,连接 数据 库 。 

第 17 行 ,声明 一 个 字符 串 型 变量 query WEW mulu KARHE. 

第 18 £T. db 对 象 调 用 query() 方 法 执行 查找 mulu 表 的 语句 ,然后 把 记录 集 的 返回 值 
赋值 给 rs。 

第 19 行 到 第 34 行 ,是 一 个 while 循环 ,循环 条 件 是 rs. next() ,直到 把 rs 中 的 所 有 记 
录 信 息 都 读 出 来 才 结 束 循环 ; 第 21 行 到 第 24 行 , 把 记录 集 里 面 的 目录 信息 使 用 get 方法 
取出 来 赋值 给 字符 串 型 变量 。 

第 26 行 到 第 33 行 , 是 表格 的 第 二 行 ,把 rs 记录 集 里 面 取出 的 目录 信息 放置 到 这 行 
的 前 四 个 单元 格 中 ,第 五 个 单元 格 和 第 六 个 单元 格 放置 目录 信息 相对 应 的 “修改 "5 和"* 删 
除 ”链接 。 

第 36 行 ,单独 一 个 段落 放置 “添加 ”链接 。 
【 源 代码 】 
[sc edit. jsp] 

1 <%@page contentType— "text/html; charset—gb2312" import="java.sql. * " %> 

2 <html> 

3 — <head><title> fal EG Fe 1B A si fri B — / title — / head 

4 <jsp:useBean id— "db" class— "bean. mydb" scope— "page" /7» 

5 <body> 

6 <% 
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7 String id= request. getParameter( "id"); 

8 ResultSet rs— null; 

9 if (id! — null) 

10 { String sdl- "SELECT * FROM mulu WHERE id='"+id+"""; 

11 db. connection() ; 

12 rs=db. query(sql) ; 

13 while (rs. next()) 

14 { String sl=rs. getString(1) ; 

15 String s2— rs. getString(2) ; 

16 String s3— rs. getString(3) ; 

i7 String s4— rs. getString(4) ; 

18 %> 

19 <div align="center"> 

20 <form name="form1" id="form1" method="post" action=""> 

21 <p> EKAR </p> 

22 <table width — "323" border ="0" cellpadding="8" cellspacing="1" bgcolor = 
" #669966"> 

23 <tr> 

24 <td width="30%" bgcolor=" # FFFFFF" align="center"> JF}: </td> 


25 <td width="70%" bgcolor=" # FFFFFF"> 
26 <input name="id" type="text" id="id" value="<%=s1%>" disabled> 
</td> 
27 </tr> 
28 <tr> 
29 <td bgcolor=" # FFFFFF" align="center" 7 fE 34: </td> 
30 <td bgcolor=" # FFFFFF"> 
31 <input name="name" type="text" id="name" value=" <% =s2% >"> 
</td> 
32 </tr> 
33 <tr> 
34 <td bgcolor=" # FFFFFF" align— "center" 7355] : </td> 
35 <td bgcolor =" # FFFFFF" ><input name =" lei" type="text" id — "lei" 
value— " « 9 —53962 "2 «1d 
36 </tr> 
37 <tr> 
38 <td bgcolor=" # FFFFFF" align="center" > H : </td> 
39 <td bgcolor =" € FFFFFF" ><input name=" timu" type="text" id=" timu" 
value="<%=s4%>"></td> 
40 </tr> 
41 <u> 
42 <td colspan— "2" align="center" valign="middle" bgcolor=" # FFFFFF"> 
43 <input type="submit" name— "Submit" value= "mM" ></td> 
44 </tr> 
45 </table> 
46 </form></div> 
47 «An 
48 id— request. getParameter("id") ; 
49 String name= db. hzsb( request. getParameter("name")) ; 


50 String lei— db. hzsb( request. getParameter( "lei")) ; 
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51 String timu= db. hzsb( request. getParameter( "timu")) ; 

52 if (id! =null && name! =null && lei! —null && timu! —null) 

53 { String sgl— "update mulu set name= '" 4- name" ', lei='"+leit"', timu— "十 
timu+"' where id= '"+id+"'"; 

54 db. connection() ; 

55 int rsn= db. update( sql) ; 

56 if (rsn>0) 

57 response. sendRedirect("shici.jsp") ; 

58 )52 

59 </body> 

60 </html> 


sc. edit, jsp 补充 说 明 

第 7 行 ,接收 shici. jsp 页 面 传递 过 来 的 id 信息 ,也 就 是 目录 所 在 mulu 表 的 序号 。 

第 9 行 ,if 语句 ,如 果 id 不 为 空 就 执行 下 面 的 语句 。 

第 10 行 ,是 一 个 sql 查找 语句 ,是 根据 id 的 值 查找 mulu 表 中 复合 的 记录 集 。 

第 13 到 第 47 行 ,是 while 循环 ,循环 条 件 是 rs. next() 直 到 把 rs 中 的 所 有 记录 信息 
都 读 出 来 才 结 束 循环 ; 第 14 行 到 第 17 行 ,把 记录 集 里 面 的 目录 信息 使 用 get 方法 取出 来 
赋值 给 字符 串 型 变量 sl 、s2、s3、s4; 第 20 行 到 第 46 行 ,是 一 个 form 表单 ; 第 22 行 到 第 
45 行 , 是 一 个 表格 ,第 23 行 到 第 27 行 是 表格 的 第 一 行 ,在 这 行 的 第 二 个 单元 格 中 放置 一 
个 文本 框 ,文本 框 的 变量 名 为 id, 默 认 值 为 sl ,而 且 文 本 框 被 设 定 为 不 可 修改 ; 第 28 行 到 
第 32 行 是 表格 的 第 二 行 ,在 这 行 的 第 二 个 单元 格 中 放置 一 个 文本 框 ,文本 框 的 变量 名 为 
name, 默 认 值 为 s2; 第 33 行 到 第 36 行 是 表格 的 第 三 行 ,在 这 行 的 第 二 个 单元 格 中 放置 
一 个 文本 框 ,文本 框 的 变量 名 为 lei ,默认 值 为 s3; 第 37 行 到 第 40 行 是 表格 的 第 四 行 ,在 
这 行 的 第 二 个 单元 格 中 放置 一 个 文本 框 ,文本 框 的 变量 名 为 timu, 默 认 值 为 s4; 第 41 行 
到 第 44 行 是 表格 的 第 五 行 ,在 这 行 放置 一 个 提交 按钮 ,用 于 提交 修改 后 的 目录 信息 。 

第 48 到 第 51 行 ,接收 前 面 表单 提交 的 已 修改 的 各 项 目录 信息 。 

第 52 行 ,让 语句 判断 如 果 表 单 提交 的 各 项 信息 都 不 为 空 ,那么 就 执行 下 面 ( 第 53 到 
第 57 行 ) 的 语句 。 

第 53 行 , 更 新 数据 库 mulu 表 中 各 项 信息 的 sql 语句 。 

第 54 £T. db 对 象 调用 connection() 方 法 链接 数据 库 ; 第 55 行 ,db 对 象 调用 updateO 77 
法 执行 数据 库 的 更 新 。 

第 56 行 到 第 57 行 ,根据 更 新 数据 库 后 的 返回 值 rsn 判断 更 新 是 否 成 功 ,如 果 更 新 成 
功 就 完成 页 面 的 跳 转 , 跳 转 到 shici. jsp 页 面 。 
【 源 代码 】 
【sc_add. html] 

1 <html> 

2 <head><title> [5] BE FE S JI A RIA — / title — / head 

3 <body> 
4 <div align="center"> 
5 
6 


<form name="form1" id="form1" method="post" action="sc_add_1.jsp"> 


<p> ğin H R</p> 


7 二 p 二 要 求 新 添加 的 目录 内 容 序号 不 能 和 已 存在 的 重复 /p> 
8 <table width="323" border="0" cellpadding — "8" cellspacing — " 1" bgcolor — 
"$4 669966" 

9 <u> 

10 <td width="30%" bgcolor=" # FFFFFF" align="center"> fF: </td> 

11 <td width="70%" bgcolor=" # FFFFFF"> 

12 <input name="id" type="text" id= "id" ></td> 

13 </tr> 

14 <u> 

15 <td bgcolor=" # FFFFFF" align="center" Ed: </td> 

16 <td bgcolor=" # FFFFFF" ><input name="name" type="text" id= "name" > 
</td> 

17 </tr> 

18 <tr> 

19 <td bgcolor=" # FFFFFF" align="center"> $l) : </td> 

20 <td bgcolor=" # FFFFFF" ><input name= "lei" type="text" id= "lei" ></td> 

21 </tr> 

22 <tr> 

23 <td bgcolor=" # FFFFFF" align— "center" 7 Bi H :</td> 

24 <td bgcolor=" # FFFFFF" ><input name— "timu" type="text" id— "timu" > 
</td> 

25 </tr> 

26 <tr> 

27 <td colspan= align="center" valign="middle" bgcolor=" # FFFFFF"> 

28 <input type="submit" name= "Submit" value=" mE" ></td> 

29 </tr> 

30 </table> 

31 </form></div> 

32 </body> 

33 </html> 


sc_add. html 补充 说 明 
第 5 行 到 第 31 行 ,是 一 个 表单 ,表单 将 把 数据 提交 到 sc_add_l. jsp 文件 ; 第 8 行 到 

第 30 行 ,是 一 个 表格 ,第 9 行 到 第 13 行 ,是 表格 的 第 一 行 ,在 这 行 的 第 二 个 单元 格 放置 一 
个 文本 框 ,变量 名 为 id, 用 于 输入 目录 的 序号 ; 第 14 行 到 第 17 行 ,是 表格 的 第 二 行 ,在 这 
行 的 第 二 个 单元 格 放 置 一 个 文本 框 ,变量 名 为 name, 用 于 输入 诗词 的 作者 ; 第 18 行 到 第 
21 行 ,是 表格 的 第 三 行 ,在 这 行 的 第 二 个 单元 格 放置 一 个 文本 框 ,变量 名 为 lei, 用 于 输入 
诗词 的 类 别 ; 第 22 行 到 第 25 行 , 是 表格 的 第 四 行 ,在 这 行 的 第 二 个 单元 格 放置 一 个 文本 
框 ,变量 名 为 timu, 用 于 输入 诗词 的 题目 ; 第 26 行 到 第 29 行 , 是 表格 的 第 五 行 ,在 这 行 里 
放置 了 一 个 提交 按钮 。 
【 源 代码 】 
[sc add 1.jspl 
<%@ page contentType-— "text/html;charset— gb2312" import="java. sql. * "967 
<html> 

<body> 

<jsp:useBean id="db" class="bean. mydb" scope="page"/> 


<%String id= request. getParameter("id") ; 
String name= db. hzsb( request. getParameter( " name")) ; 


c» c & 0 to 


O (semwmirsst dae] 0o 


7 String lei— db. hzsb( request. getParameter("lei") ) ; 

8 String timu— db. hzsb( request. getParameter("timu")) ; 

9 if (id! — null & & name! — null && lei! —null && timu! —null) 

10 (String sql— "INSERT INTO mulu VALUES("-- "V" -Fid-- "V" ", "E "V" 4 named- 
机 

11 db. connection() ; 

12 int rsn— db. update(sql) ; 

13 if (rsn>0) 

14 response. sendRedirect( "shici. jsp") ; 

15 }%> 

16 </body> 

17 </html> 


sc_add_1. jsp 补充 说 明 
第 1 行 ,引入 java 类 的 SQL 包 , 因 为 下 面 代 码 用 到 了 SQL 命令 。 
第 4 行 ,使 用 useBean 动作 ,使 用 的 类 是 bean 文件 夹 下 的 mydb 类 ,类 的 对 象 为 db。 
第 5 行 到 第 8 行 ,接收 sc. add. html 文件 传递 过 来 的 各 项 诗词 信息 ,并 且 使 用 db 对 
象 调用 hzsb() 方 法 ,以 防 用 户 输入 汉字 产生 乱码 。 
第 9 行 到 第 15 行 , 是 一 组 计 语 句 , 当 所 有 诗词 目录 信息 都 不 为 空 的 时 候 执行 ff 语句 
中 的 所 有 操作 。 
第 10 行 ,声明 一 个 字符 串 型 变量 SQL ,赋值 为 向 mulu 表 插 入 诗词 信息 的 句子 。 
第 11 行 , 使 用 db 对 象 调用 connection ) 方 法 连接 数据 库 。 
第 12 行 ,使 用 db 对 象 调用 update( ) 方 法 执行 对 mulu 表 的 记录 插入 ,并 把 返回 值 赋 
给 整形 变量 rsn。 
第 13 行 到 第 14 行 ,是 一 组 让 语句 ,如 果 rsn 的 返回 值 大 于 0, 就 表示 上 一 句 的 记录 插 
和 成功 ,那么 就 可 以 直接 跳 转 到 shici. jsp 界面 。 
【 源 代 码 】 
【sc_del. jsp] 
1 <%@page contentType="text/html; charset=gb2312" import="java.sql. * " %> 
2 <html> 
3 <head> 
4 < 一 title 之 删除 指定 目录 信息 二 /title> 
5 </head> 
6 <jsp:useBean id="db" class="bean. mydb" scope="page"/> 
T 
8 


<body> 
<% 

9 String id= request. getParameter("id") ; 
10 if (id! =null) 
11 { 
12 String sql="DELETE FROM mulu WHERE id="+"\'"+id+"\""; 
13 db. connection() ; 
14 db. delete(sql) ; 
15 response. sendRedirect( "shici. jsp") ; 


17 »— 
18 </body> 
19 </html> 


实战 演练 2 一 一 图 书库 存 情况 的 查找 


【题目 】 

要 求 在 界面 上 显示 全 部 图 书 的 库存 信息 情况 ,并 且 可 以 根据 图 书 的 序号 . 书 名 、 作 者 、 
出 版 社 、 类 型 单价、 库存 查找 书籍 。 
【分 析 】 


(1) 打开 SQL 软件 的 企业 管理 器 ,新 建 数 据 库 chazhao, 如 图 5-53 所 示 。 
(2) 在 chazhao 数据 库 中 新 建 库存 表 book, 表 的 设计 情况 如 图 5-54 所 示 。 


$ SQL Server Enter... E DKR 

=la) x] 

DDO 操作 (A) EV IAW BAW 

e- GB 4 xi?B Ow ^d 

名 控制 各 根 目 录 ye 

i Diicrosoft SQL Serve 名 称 ^ 
S SUL Server 组 一 : 


S ib (local) (indo x ie] 
b OUR Elátpropertie: 数据 类 型 


Scolumns 
aO bookshop — | Einer à wrda 
5 日 chazhao —— |F]sysdepends nvarchar 

国 sysfilegrow 

国 sysfiles 

国 sysfilesl h 

Eisysforei enke mardi 
gi Deystullterteg 


出 版 社 


nvarchar 
nvarchar 


8 83/83 8 8 8 Sly 


图 5-53 ”新建 数据 库 chazhao 图 5-54 book 表 的 设计 


(3) 建立 ODBC 数据 源 ,打开 系统 管理 工具 一 一 ODBC 数据 源 对 话 框 ,添加 chazhao 
数据 源 , 如 图 5-55 所 示 。 


ODBC 数据 源 管 理 器 


FAP DSN | 系统 osm | 文件 IST | 驱动 程序 | 跟踪 | 连接 池 | 关于 | 


用 户 数据 源 Q ; 

aii ESEA mo) 
bookshop ‘SQL Server 

SQL Server 删除 8) 
dBASE Files Microsoft dBase Driver (* dbf) 

denglu SQL Server. 

Excel Files Microsoft Excel Driver (*.xls) EEO 
message SQL Server 

MS Access Database Microsoft Access Driver (*.mdb 

shici SQL Server 

Visual FoxPro Database Microsoft Visual FoxPro Driver 

Visual FoxPro Tables Microsoft Visual FoxPro Driver 

s > 


图 5-55 添加 chazhao 数据 源 


(4) 题目 中 需要 的 代码 文件 有 : mydb. java 完成 保存 连接 数据 库 的 代码 和 用 于 对 数 
据 库 进行 增删 改 查 以 及 汉字 识别 的 方法 ; chaz. jsp 文件 完成 查找 项 目的 表格 设计 ,并 且 


O (masmmgits weise] 0000 


把 chaz_1.jsp 文件 的 内 容 引 入 进来 ,使 两 个 文件 的 显示 内 容 合 二 为 一 ; chaz_1. jsp 文件 
可 以 显示 图 书库 存 的 所 有 情况 ; result. jsp 文件 设计 了 图 书 的 查找 结果 的 表格 ,并 且 把 
result_1. jsp 文件 的 内 容 引 入 进来 ,使 查找 结果 显示 在 表格 中 ; result_1. jsp 文件 显示 图 
书 的 查找 结果 。 
【运行 效果 】 

打开 开发 工具 MyEclipse, 在 工程 jsp-jdbc 的 bean 文件 夹 中 修改 mydb. java 文件 。 
在 这 个 工程 的 WebRoot 文件 夹 下 ,新建 文件 chaz. jsp .chaz_1. jsp、result. jsp、result_1. jsp. 
程序 输入 完毕 并 且 保 存 之 后 ,运行 开发 工具 MyEclipse 中 的 Tomcat 服务 器 。 最 后 在 浏 
览 器 中 输入 地 址 http://127. 0. 0. 1:8080/jsp-jdbc/chaz. jsp, 就 可 以 看 到 运行 结果 了 (如 
图 5-56 和 图 5-57 Bras). 


图 书 管理 >》 > SE 
msn. | BSE. | 作者 , | 
出 版 社 ， | al [etw 
全 部 图 书 如 下 
BSD 图 书 名 称 作者 出 版 社 类 别 价格 库存 
1 计算 机 基础 x 高 教 出 版 社 教育 20 4 
2 财富 se 上 海 生活 20 T 
3 旅行 者 ss rm 生活 15 10 
4 绝对 小 孩儿 m 文艺 出 版 社 娱乐 23 8 
5 网 络 技术 mr 人 民 邮 电 出 版 社 教育 12 10 
6 Fifa tt 人 民 邮 电 出 版 社 生活 34 6 
45 


7 广告 创意 LÀ STALE 科技 44 


Æ 5-56 chaz. jsp 


图 书 ID 图 书 名 称 作者 出 版 社 类 别 (uh ”库存 
1 计算 机 基础 xs aA 教育 20 4 
5 网 络 技术 we 信 民 邮包 出 版 社 教育 12 10 
返回 所 有 图 书 首页 


图 5-57 result. jsp 


CERE] 
[mydb. java] 


package bean; 
import java. sql. * ; 
public class mydb { 


try{ 
Class. forName( "sun. jdbc. odbc. JdbcOdbcDriver") ; 


1 

2 

3 

4 

5 public void connection { 
6 

7 

8 conn= DriverManager. getConnection("jdbe:odbe: chazhao") ; 
9 


We AUT [ 情境 五 sp 数据库 应 用 | «& o 


mydb. java 补充 说 明 
这 个 文件 和 上 一 个 题目 的 文件 是 一 样 的 ,只 需 将 第 8 行 代码 中 数据 库 的 名 字 改 成 
chazhao 就 可 以 通用 这 整 篇 代码 了 。 


【 源 代码 】 
(chaz. jsp] 
1 <%@page contentType="text/html; charset=gb2312" import= "java. sql. * "% > 
2 <html> 
3 <head><title> # Hi fi </title></head> 
4 <body> 
5 <form id— "form1" name="forml" method="post" action= "result. jsp" > 
6 <table width="900" border="1" align="center" cellpadding="0" cellspacing="0"> 
T <tr> 
8 <td height — "30" colspan="6" align="left" valign =" middle" bgcolor = 
"£ CCCCCC" > 图 书 管理 )) 查 询 图 书 一 /td> 
9 </tr> 
10 <tr> 
11 <td height="15" align="right" valign="middle" width="80"> R ID: </td> 
12 <td align="left" valign= "middle"— 
13 <input name="bookid" type="text" id="textfield" /></td> 
14 <td align="right" valign="middle" width— "80" 2H 4544 f: </td> 
15 <td align="left" valign— "middle"— 
16 <input type="text" name= "bookname" id— "textfield2" /></td> 
17 <td align="right" valign="middle" width— "80" E34: </td> 
18 <td align="left" valign="middle"> 
19 <input type="text" name= "author" id— "textfield3" /></td> 
20 </tr> 
21 <tr> 
22 <td height="15" align="right" valign="middle" 之 出 版 社 : </td> 
23 <td align="left" valign="middle"> 
24 <input type="text" name— "publisher" id="textfield4" /> </td> 
25 <td align="right" valign="middle" 73553]: </td> 
26 <td align="left" valign= "middle" 
27 <select name= "category" id= "select" > 
28 <option >null</option> 
29 <option >#}4% </option> 
30 <option>% #</option> 
31 <option># if </option> 
32 <option>#t 2</option> 
33 <option># ik </option> 
34 <option># ff </option></select></td> 
35 <td colspan="2" align="center" valign="middle" > 
36 <input type="submit" name— "button" id="button" value= "Zt 4%" /></td> 
37 </tr></table></form> 
38 <% @include file=”chaz_1.jsp” %> 
39 </body> 


40 </html> 
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chaz. jsp 补充 说 明 

第 5 行 到 第 37 行 , 是 一 个 表单 ,表单 的 数据 将 提交 到 result. jsp; 第 6 行 到 第 37 fT. 
是 一 个 表格 ; 第 7 行 到 第 9 行 , 是 表格 的 第 一 行 ; 第 10 行 到 第 20 行 ,是 表格 的 第 二 行 ,在 
这 行 的 第 二 个 格 放 置 了 一 个 文本 框 ,变量 名 为 bookid, 用 于 输入 图 书 ID ,第 四 个 格 放置 了 
一 个 文本 框 ,变量 名 为 bookname, 用 于 输入 图 书 名 称 ,第 六 个 格 放置 了 一 个 文本 框 ,变量 
名 为 author, 用 于 输入 书籍 作者 ; 第 21 到 第 37 行 , 是 表格 的 第 三 行 ,在 这 行 的 第 二 个 格 
放置 了 一 个 文本 框 , 变 量 名 为 publisher, 用 于 输入 出 版 社 , 第 四 个 格 ,放置 一 个 下 拉 框 , 变 
量 名 为 category, 第 五 个 格 放置 了 一 个 提交 按钮 ; 第 38 行 ,引入 了 chaz 1. jsp 文件 ,可 以 
在 页 面 中 显示 图 书库 存 的 所 有 情况 。 
【 源 代码 】 
[chaz 1. jsp] 


1 <%@page contentType— "text/html; charset— gb2312" import="java.sql. * "% > 

2 <html> 

3 <jsp:useBean id— "db" class="bean. mydb" scope="page"/> 

4 <body> 

5 <br><h2>278 E 3 MF </h2> 

6 <table width="900" border— "0" cellspacing— "0" cellpadding="0"> 

7 <tr> 

8 <td height— "30" align="center" valign="middle" bgcolor =" i£ CCCCCC" [d 45 
ID&-nbsp;</td> 

9 <td height— "30" align="center" valign="middle" bgcolor=" # CCCCCC">A P% 
称 &nbsp; </td> 

10 <td height="30" align="center" valign="middle" bgcolor=" # CCCCCC" >% # 
&-nbsp; </td> 

11 <td height— "30" align="center" valign="middle" bgcolor=" € CCCCCC"> Hi hätt 
& nbsp; </td> 

12 <td height— "30" align="center" valign="middle" bgcolor=" € CCCCCC" >% Jl 
& nbsp;</td> 

13 <td height— "30" align="center" valign="middle" bgcolor =" # CCCCCC" > fft ffs 
&-nbsp; </td> 

14 <td height="30" align="center" valign="middle" bgcolor =" # CCCCCC" > E f£ 
&nbsp;</td> 

15 </tr> 

16 <% 

17 ResultSet rs— null; 

18 db. connection) ; 

19 String query "select * from book"; 

20 rs— db. query(query) ; 

21 while (rs. next ) 

22 ( String s1=rs. getString(1) ; 

23 String s2— rs. getString(2) ; 

24 String s3— rs. getString(3) ; 

25 String s4— rs. getString(4) ; 

26 String s5— rs. getString(5) ; 


27 String s6— rs. getString(6) ; 


MOM OM ONU MM MM CVM [ 情境 五 J5P 数 据 库 必用 | « > 


28 String s7=rs. getString(7) ; %> 
29 uu 
30 <td height— "30" align="center" iddle" ><% =s1% ></td> 
31 <td height="30" align="center" middle" >< %=s2% ></td> 
32 <td height= "30" alig: center" valign="middle" >< % =s3% ></td> 
33 <td height="30" align="center" valign="middle" >< % =s4% ></td> 
34 <td height="30" align="center" valign="middle" ><% =s5% ></td> 
35 <td height="30" align="center" valign="middle" ><% =s6% ></td> 
36 <td height="30" align="center" valign="middle" ><% —57 4 ></td> 
37 </tr> 
38 <% } %></table> 
39 </body> 
40 </html> 

result. jsp] 


1 <%@ page contentType— "text/html; charset=gb2312" import= "java. sql. * "% > 

2 <html > 

3 <head> <title> E if] 4 8. — / title — / head 

4 «jsp: useBean id — "db" class— "bean. mydb" scope— "page" /7* 

5 <body> 

6 <center> 

7 <form id— "forml" name="form1" method="post" action=""> 

8 <table width="700" border="0" cellspacing="0" cellpadding="0"> 

9 <tr> 

10 <td height ="30" align="center" valign="middle" bgcolor =" # CCCCCC" > 
&nbsp; 图 书 ID 一 /td> 


11 "30" align="center" valign="middle" bgcolor=" # CCCCCC" [8 45 
/td> 

12 <td height="30" align="center" valign="middle" bgcolor=" # CCCCCC" E34 
&nbsp;</td> 

13 <td height="30" align="center" valign="middle" bgcolor=" # CCCCCC"> itt hit 
社 &nbsp;</td> 

14 <td height — "30" align="center" valign="middle" bgcolor=" # CCCCCC" > 2 Jl 

&nbsp; </td> 
15 <td height — "30" align="center" valign="middle" bgcolor=" # CCCCCC" fft f& 
&nbsp; </td> 

16 <td height="30" align="center" valign="middle" bgcolor=" # CCCCCC"> JE f£ 
nbsp; </td> 

17 </tr> 

18 <% String id= db. hzsb( request. getParameter("bookid")) ; 

19 String bookname= db. hzsb( request. getParameter(" bookname")) ; 

20 String author— db. hzsb( request. getParameter( "author")) ; 

21 String publisher— db. hzsb( request. getParameter( "publisher")) ; 

22 String category — db. hzsb(request. getParameter( "category" )) ; 

23 ResultSet rs— null; 

24 String sqls 一 "SELECT * FROM book WHERE id 一 "十 id 十 "'OR name= '"+ 


bookname+"' OR author= '"+author+"' OR publisher = '" + publisher +" ' OR 
type='"+category+"'"; 
25 db. connection() ; 
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26 rs— db. query(sqls) ; 

27 while (rs. next()) 

28 { String sl —rs. getString(1) ; 

29 String s2— rs. getString(2) ; 

30 String s3— rs. getString(3) ; 

31 String s4— rs. getString(4) ; 

32 String s5— rs. getString(5) ; 

33 String s6— rs. getString(6) ; 

34 String s7 — rs. getString(7) ; 

35 X 

36 <tr> 

37 <td height= "30" — "center" valign="middle" >< % =s1% ></td> 
38 <td height= "30" "center" valign="middle" >< % =s2% ></td> 
39 "center" valign="middle" >< 9 — s396 ></td> 


40 <td height= "30" "center" valign= "middle" ><% — s4 4 ></td> 
4l <td height— "30" align="center" valign="middle" — Y — s596 ></td> 
42 <td height — "30" align="center" valign="middle" >< ?6 — s6 94 ></td> 
43 <td height— "30" align="center" valign="middle" — ?6 — s7 96 ></td> 
44 </r><% ) X 
45 </table></form> 
46 <br><a href="chaz. jsp" >38 ELA AB </a> 
47 </center> 
48 </body> 
49 </html> 

实战 演练 3 一 一 留言 板 

【题目 】 


留言 板 要求 浏 览 的 用 户 能 够 留言 ,并且 能 够 看 到 全 部 留言 ,留言 包括 留言 主题 .留言 
人 、 留 言 内 容 、 留 言 时 间 , 并 且 要 按照 最 近 的 留言 最 先 看 到 的 顺序 显示 留言 。 
【分 析 】 

(1) 打开 SQL 软件 的 企业 管理 器 ,新 建 数据 库 message, 如 图 5-58 所 示 。 


* SQL Server Enter... [c DKR 


DBlatpropertie: 
国 message 
国 syscolums 

- | 目 syscomments 
国 sysdepends 
Elsysfilezrou 
国 sysfiles 
国 sysfilesl 
国 sysforeignkt 

£ ABE a Elsysfulitext 


B 


图 5-58 message 数据 库 


IDEEN [ 情境 五 J5P 数 据 库 必用 FON 


(2) f£ message 数据 库 中 新 建 库存 表 message, 表 的 设计 情况 如 图 5-59 所 示 。 


title 
nane 
message 
[tine] 


留言 时 间 


图 5-59 message 表 设 计 


(3) 建立 ODBC 数据 源 ,打开 系统 管理 工具 一 一 ODBC 数据 源 对 话 框 , 添 加 message 
数据 源 , 如 图 5-60 所 示 。 


ODBC 数据 源 管 理 器 
FAP DSN | 系统 nsw | 文件 nsu | SEsbPU | 跟踪 “| 连接 池 | x 


用 户 数据 源 QD: 

[am | 驱动 程序 

‘bookshop ‘SQL Server 

chazhao SQL Server 

dBASE Files Microsoft dBase Driver (+. dbf) 
denglu SQL Server 

Excel Files Microsoft Excel Driver (*.xls) 

SQL Server 

WS Access Database Microsoft Access Driver (*.mdb 
shici SQL Server 


Visual FoxPro Database Microsoft Visual FoxPro Driver 
Visual FoxPro Tables Microsoft Visual FoxPro Driver 
< > 


Æ 5-60 AM ODBC 数据 源 


(4) liuyan_show, jsp 文件 在 这 个 页 面 中 完成 对 message 表 中 所 有 信息 的 倒序 显示 
工作 。 本 页 面 还 包含 了 “我 要 留言 "的 链接 ,可 以 链接 到 留言 页 面 。liuyan. jsp 文件 完成 
的 功能 是 添加 记录 的 界面 设计 ,其 中 有 一 个 表单 和 一 个 表格 , 当 用 户 想 要 留言 , 单 击 
【留言 按钮 的 时 候 , 表 单 中 的 内 容 就 会 提交 到 liuyan_add. jsp 代码 页 中 。liuyan_add. jsp 
文件 没有 界面 设计 ,完成 的 功能 是 接收 liuyan. jsp 文件 的 表单 提交 的 信息 ,进行 数据 库 更 
新 ,如 果 更 新 成 功 则 返回 首页 查看 结果 。 

【运行 效果 】 

打开 开发 工具 MyEclipse, 在 工程 jsp-jdbc 的 bean 文件 夹 中 复制 mydb. java 文件 为 
mydb_m. java, 并 修改 mydb_m. java 文件 ; 在 这 个 工程 的 WebRoot 文件 夹 下 ,新 建文 件 
liuyan show. jsp, liuyan. jsp,liuyan_add. jsp。 程 序 输入 完毕 并 且 保 存 之 后 ,运行 开发 工 
具 MyEclipse 中 的 Tomcat 服务 器 。 最 后 在 浏览 器 中 输入 地 址 http://127. 0. 0. 1:8080/ 
jsp-jdbc/liuyan_show. jsp, 就 可 以 看 到 运行 结果 了 (如 图 5-61 和 图 5-62 所 示 ) 。 

【 源 代码 】 
[mydb m. java] 
package bean; 


1 

2 import java.sql. * ; 

3 public class mydb m { 
4 
5 


public void connection() { 


2011-12-2 14:2:45 


你 这 说 的 都 挨 着 吗 


2011-12-2 13:58:53 
REVEL. VEMLAARAS 


二 伯 


2011-12-2 13:56:44 


Æ 5-61 liuyan_show. jsp 


DETK 


Æ 5-62 liuyan. jsp 


6 try{ 

7 Class. forName( "sun. jdbc. odbe. JdbeOdbcDriver" ) ; 

8 conn=DriverManager. getConnection( "jdbc: odbc: message ") ; 

9 stmt= conn. createStatement (ResultSet. TYPE_SCROLL_SENSITIVE, ResultSet. CONCUR_ 
READ ONLY); 

10 … 


mydb m. java 补充 说 明 
这 里 忽略 了 该 文件 与 上 一 个 题目 的 文件 内 容重 复 的 地 方 , 只 给 大 家 展示 不 同 之 处 。 
第 3 行 , 公 共 类 的 名 字 mydb_m:, 与 本 文件 名 相同 ; 第 8 行 ,把 数据 库 的 名 字 改 成 了 
message; 第 9 行 ,在 stmt 赋 初 值 的 时 候 不 同 ,stmt 的 这 个 改变 是 用 于 留言 板 记录 显示 时 
发 挥 作用 ,这 其 中 TYPE SCROLL SENSITIVE 该 常量 指示 可 滚动 并 且 通 常 受 其 他 的 
更 改 影响 的 ResultSet 对 象 的 类 型 ,CONCUR_READ_ONLY 该 常量 指示 不 可 以 更 新 的 
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ResultSet 对 象 的 并 发 模式 。 
【 源 代码 】 
[liuyan_show. jsp] 


1 <%@ page contentType="text/html; charset=gb2312" import= "java. sql. *" %> 
2 <html> 

3 <head> 

4 <title> lo B A </title> 

5 <style type="text/css"> 

6 xr. 

7 .STYLEI (color: #669900} 

8 --> 

9 </style> 

10 </head> 

11 <jsp:useBean id— "db" class= "bean. mydb m" scope="page"/> 
12 <body> 


13 <p align="center" ><h2 align="center" ><a href ="liuyan. jsp" >R &nbsp; € 
& nbsp; & nbsp; a@</a></h2> 
14 <div align="center"> 


15 <% 

16 ResultSet rs— null; 

17 db. connection() ; 

18 String query— "select * from message "; 

19 rs— db. query(query) ; 

20 rs.afterLast() ; 

21 while (rs. previous() ) 

22 { String s1— rs. getString(1) ; 

23 String s2— rs. getString(2) ; 

24 String s3— rs. getString(3) ; 

25 String s4— rs. getString(4) ; 

26 5n 

27 <table width— "563" height— "118" border— "0" bgcolor=" € CC9900" cellspacing = 

"2" cellpadding— "8"— 

28 <tr> 

29 <td width="20%" bgcolor=" # FFFFCC" ><span class="STYLE3 STYLE1"> fi 
A EE: </span> </td> 

30 <td colspan="3" ><% =s1% ></td> 

31 </tr> 

32 <tr> 

33 <td bgcolor=" # FFFFCC"><span class="STYLE3 STYLE1"> f A: </span> 
</td> 

34 <td bgcolor=" # ffffff" ><% =s2%></td> 

35 </tr> 

36 <tr> 

37 <td bgcolor=" # FFFFCC"><p class="STYLE1"> Bi zi Ht] : </p> </td> 

38 <td colspan— "3" bgcolor=" + ffffff" ><% =s4% ></td> 

39 </tr> 

40 <u> 


41 <td bgcolor=" # FFFFCC"><p class 一 "STYLE3 STYLE1"> 8A &:</p> 


O CAO 


</td> 
42 <td colspan="3" bgcolor=" + ffffff" ><% =s3% ></td> 
43 </tr> 
44 </table> 
45 <p> 
46 <% } W- 


47 </div> 
48 <p align="center" ><h2 align =" center" ><a href ="liuyan. jsp" >R &nbsp; € 
& nbsp; & nbsp; a@</a></h2> 

49 </body> 

50 </html> 
liuyan show. jsp 补充 说 明 

第 1 行 ,引入 java 类 的 SQL 包 , 因 为 下 面 代 码 用 到 了 sql 命令 。 

第 11 行 ,使 用 useBean 动作 ,使 用 的 类 是 bean 文件 夹 下 的 mydb_m 类 ,类 的 对 象 
为 db。 

第 19 行 ,db 对 象 调用 query() 方 法 执行 查找 message 表 的 语句 ,然后 把 记录 集 的 返 
回 值 赋值 给 rs。 

第 20 行 ,为 了 疼 序 输出 记录 , 需 将 rs 的 记录 指针 移动 到 最 后 一 行 记录 之 后 。 

第 21 行 到 第 46 行 ,是 一 个 while 循环 ,循环 条 件 是 当 rs 移动 到 第 一 条 记录 之 前 就 终 
止 循环 ; 第 22 行 到 第 25 行 ,把 记录 集 里 面 的 目录 信息 使 用 get 方法 取出 来 赋值 给 字符 串 
型 变量 sl 、s2、s3、s4; 第 27 行 到 第 44 行 ,是 一 个 表格 ,第 28 行 到 第 31 行 是 表格 的 第 一 
行 , 在 这 行 的 第 二 个 单元 格 中 放置 sl; 第 32 行 到 第 35 行 是 表格 的 第 二 行 ,在 这 行 的 第 二 
个 单元 格 中 放置 s2; 第 36 行 到 第 39 行 是 表格 的 第 三 行 ,在 这 行 的 第 二 个 单元 格 中 放置 
s4; 第 40 行 到 第 43 行 是 表格 的 第 四 行 , 在 这 行 的 第 二 个 单元 格 中 放置 s3 。 

第 48 行 是 “我 要 留言 "的 链接 liuyan. jsp. 


【 源 代码 】: 
【liuyan. jsp] 
1 <%@page contentType= "text/html; charset=gb2312" import— "java.sgl. * " %> 
2 <html> 
3 <head> 
4 <title> B zi </title> 
5 <style type="text/css"> 
6 <!-- 
T .STYLE1 { color: #669900} 
8 --> 
9 </style> 
10 </head> 
11 <body> 
12 <form id="forml" name="forml" method="post" action= "liuyan_add.jsp"> 
13 <p><hl align="center" class="STYLE1"> &nbsp; & nbsp; £f &nbsp; &nbsp; 板 
</h1> 
14 < table width — "300" height =" 123" border — "0" align="center" cellpadding = " 8" 


cellspacing— "2" bgcolor=" # CC9900"— 
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15 xu 

16 <td width— "3074" bgcolor=" & FFFFCC"><span class- "STYLE1"7- B AA: 
</span></td> 

17 <td width="315" bgcolor=" # FFFFCC"><input name="name" type="text" 
size= "20" maxlength="10"/></td> 

18 </tr> 

19 <tr> 

20 <td bgcolor=" # FFFFCC"><span class="STYLE1"> M 7$ EM: </span> </td> 

21 <td bgcolo: " # FFFFCC" ><input name=" title" type="text" size = "20" 
maxlength="20"/></td> 

22 </tr> 

23 <tr> 

24 <td colspan="2" bgcolor=" # FFFFCC"><span class="STYLE1">& # AZ: 
</span></td> 

25 </tr> 

26 <tr> 

27 <td colspan — "2" >< textarea name =" message" cols ="50" rows="6" > 
</textarea></td> 

28 </tr> 

29 <tr> 

30 <td colspan= align="center"> 

31 <input name="ok" type="submit" class="STYLE1" value=" zi" /> 

32 & nbsp; &-nbsp; &-nbsp; &-nbsp; 

33 <input name= "reset" type— "reset" class 一 "STYLE1" value=" 重 填 " /></td> 

34 </tr></table></form> 

35 </body> 

36 </html> 

liuyan. jsp 补充 说 明 


在 这 段 代 码 中 GregorianCalendar 是 Calendar 类 (标准 的 日 历 ) 子 类 ,使 用 
GregorianCalendar 类 声明 的 对 象 可 以 调用 Calendar 类 的 方法 获取 有 关 日 期 和 时 间 的 信息 。 


1 <%@page contentType="text/html; charset=gb2312" import="java.sql. *" %> 
2 <%@page import— "java. util. * "%> 

3 <html> 

4 <head><title> i 4m B zi — / title — / head 

5 <jsp:useBean id — "db" class— "bean. mydb m" scope— "page" /7* 

6 <body> 

$ <% String title=db. hzsb( request. getParameter("title") ) ; 

8 String name= db. hzsb( request. getParameter( "name" ) ) ; 

9 String message= db. hzsb( request. getParameter( " message") ) ; 


10 GregorianCalendar calen= new GregorianCalendar() ; 

11 String t= Integer. toString( calen. get(Calendar. YEAR)) +"-" + Integer. toString (calen. 
get(Calendar. MONTH) 4 1) +"-" + Integer. toString (calen. get (Calendar. DAY_OF_ 
MONTH)); 

12 String tm=t+" "+ Integer. toString (calen. get (Calendar. HOUR_OF_DAY)) 十 ":" 十 


Integer. toString ( calen. get (Calendar. MINUTE)) +": 
(Calendar. SECOND) ) ; 
13 String time=tm; 


+ Integer. toString (calen. get 
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14 if (title! —null & & name! —null && message! = null) 

15 { String rssql="INSERT INTO message VALUES(" 4- "V" c titlec- "V4 n, "nmn 
-F name "V" 4", " 3-"V'"-Emessaged- V" 4r", " 4 "V" Tr timeo "V" ")"; 

16 db. connection() ; 

17 int rsn=db. update(rssql) ; 

18 if (rsn>0) 

19 response. sendRedirect("liuyan_show. jsp") ; 

20 MW 

21 — </body> 

22 </html> 


拓展 一 一 分 页 功能 


【题目 】 

在 上 一 题 的 基础 上 ,要 求 显示 留言 的 时 候 , 每 页 只 显示 两 条 留言 记录 ,计算 出 数据 库 
中 的 留言 总 共 可 以 分 成 几 页 显示 ,并 且 把 能 够 显示 的 页 面 总 数 和 每 一 页 的 链接 显示 出 来 。 
另外 要 求 对 于 留言 内 容 可 以 识别 空格 和 回 车 。 
【运行 效果 】 

运行 效果 如 图 5-63 所 示 。 


我 要 留言 
留言 主题 
PBA: zzz 
留言 时 间 2014-5-30 13:23:40 


gene: [m 


sa 


2014-5-30 14:33:12 


sssssssssssssssssss 
s s s s 
留言 内 容 S sssssss sssssss s 

S sssss sssss s 
s sss sss s 
sssssssssssssssssss 


D] [2 [3] I4 I [5 Id [8 35 


图 5-63 显示 留言 结果 界面 liuyan_show. jsp 


【 源 代码 】 


【replace. java] 


1 package bean; 

2 public class replace { 

3 private String content=""; 

4 public void setContent( String content) 

5 { 

6 this. content= content; 

7 this. content= this. content. replaceAll(" ", "&nbsp;"); 
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8 this. content 一 this. content. replaceAll("\r\n", "<br>"); 

9 } 

10 public String getContent() 

11 (return this. content; ) 

12 } 
replace, java 补充 说 明 

第 7 行 , 把 留言 中 的 空格 ” ”用 &nbsp; 表 示 ; 第 8 行 ,把 留言 中 的 回 车 用 “二 br 二 ” 
表示 。 
DEREI 


[liuyan show. jsp] 


1 


<%@ page contentType- "text/html; charset=gb2312" language— "java" import= "java. sql. 
x" X» 
<html> 
<head> 
<title> ERM A </title> 
<style type="text/css"> 
.STYLE1 (color: #669900} 
</style> 
</head> 
<jsp:useBean id="db" class= "bean. mydb" scope="page"/> 
<jsp:useBean id= 
<body> 
<p align="center" 7 — h2 align =" center" ><a href — "liuyan. jsp" >R & nbsp; € 
&nbsp; M & nbsp; 7#</a></h2> 
<div align="center"> 
<% 
int row_page=0; 
int per_show=2; 


zh" class= "bean. replace" scope="page"/> 


int row_count=0; 
int now_page=1; 
ResultSet rs= null; 
db. connection() ; 
String query— "select * from message "; 
rs— db. query(query) ; 
rs.lastO ; 
row count— rs. getRow() ; 


row page— (row, count/4 per show-— —0)?(row  count/per show):(row count/per 


show 1); 
String temp— request. getParameter("to page"); 
if(temp— — null) 
now page—]l; 
else 
now page- Integer. parseInt(temp) ; 
if(row_count>0) 
{ 
rs. absolute(per_show * (now_page-1) +1); 
for(int i=1;i<—=per_show;i++) 
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35 { 
36 if(!rs.isAfterLast()) 
37 { 
38 String sl=rs. getString(1) ; 
39 String s2=rs. getString(2) ; 
40 String s3— rs. getString(3) ; 
41 String s4=rs. getString(4) ; 
42 zh. setContent(s3) ; 
43 s3=zh. getContent() ; 
44 %> 
45 <table width="563" height="118" border="0" bgcolor=" # CC9900" cellspacing = 
"2" cellpadding="8"> 
46 <tr> 
47 <td width="20%" bgcolor=" ££ FFFFCC"><span class="STYLE3 STYLE1"> f 
A EM: </span> </td> 
48 <td colspan= "3"> <% =s1% ></td> 
49 </tr> 
50 <tr> 
51 <td bgcolor =" # FFFFCC" ><span class =" STYLE3 STYLE1" 二 留言 人 : 
</span> </td> 
52 <td bgcolor=" # ffffff" ><% =s2% ></td> 
53 </tr> 
54 <u> 
55 <td bgcolor=" # FFFFCC"><p class="STYLEL"> Ri i Bt 8] «</p> </td> 
56 <td colspan="3" bgcolor=" # ffffff" ><% =s4% ></td> 
57 </tr> 
58 <tr> 
59 <td bgcolor=" # FFFFCC"><p class 一 "STYLE3 STYLE1"> M R VIE :— / p 
</td> 
60 <td colspan— "3" bgcolor=" # ffffff" ><% =s3 % ></td> 
61 </tr> 
62 </table> 
63 <p> 
64 <% 
65 rs.next();}}} 
66 n» 


67 </div> 
68 <p align="right"> 
69 <% for(int i=1;i<=row_page;i++) 


70 { 

71 5n 

72 &nbsp;<a href— "shici.jsp?to page— <% =i %>" 2 [« 96 —i 942» ] / a2» &nbsp; 
<% ) x 

73 4<% — row. page 262» Jt 

74 </body> 

75 </html> 


liuyan_show. jsp 补充 说 明 
第 15 到 第 18 行 ,row_page 记录 集 总 共 可 以 显示 几 页 ;per_show 设置 每 页 显示 几 条 
记录 ; row count 记录 集 总 数 ;now_page 当前 页 码 。 


(Cee ce | Kn | 


第 24 行 ,整形 变量 row_count 赋值 为 记录 集 总 数 。 

第 25 行 ,计算 记录 集 总 共 可 以 显示 几 页 。 

第 26 行 , 通 过 参数 获取 当前 页 码 。 

第 33 行 ,将 指针 移 到 需要 显示 页 的 第 1 个 数据 。 

第 42 行 ,把 留言 中 的 空格 和 回 车 做 相应 的 转换 才能 在 输出 中 显示 出 来 。 


本 章 小 结 


JSP 数据 库 应 用 开发 是 ISP 开发 中 的 重点 和 难点 ,只 有 掌握 了 数据 库 的 开发 ,JSP 才 
能 发 挥 其 最 大 功效 。 本 章 从 数据 库 出 发 ,依次 介绍 了 SQL 数据 库 的 安装 与 使 用 、JDBC 
驱动 程序 JDBC 编程 ,并 且 通 过 若干 实例 介绍 了 如 何在 JSP 中 进行 数据 库 应 用 开发 。 


本 章 习 题 
综合 练习 1 教育 网 站 


[RI 
制作 一 个 教育 网 站 (图 5-640 ,要 求 登 录 网 站 的 用 户 可 以 浏览 网 站 的 所 有 内 容 , 并 且 
可 以 注册 成 为 网 站 的 会 员 ,成 为 会 员 之 后 就 可 以 下 载 网 站 上 的 学 习 资料 。 浏 览 网 站 的 用 
户 可 以 在 网 站 上 交流 ,所 以 要 求 网 站 有 一 个 留言 板 模块 (图 5-65 和 图 5-66) 。 
器 5.0 正式 版 六 件 (F) 查看 (Y) 收藏 
Ò BPSK ARA- OMR- DMR- Jip- PERES WME- 
* Bum Q WLR 
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图 5-64 网 站 首页 


9 内 容 选取 
o ignes 1 Web 技术 、 环 境 措 建 PPT Ja 
? 才 现 形式 :Java 编程 语言 基础 P zm 
? Hi o 3 JSP 指令 元 素 和 动作 元 素 PPT IE 
a JSP 对象， 
5 JavaBean: 
6 Servlet: 
7 数据 库 : 
s 综合 训练 : 
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图 5-65 可 以 下 载 学 习 资料 的 页 面 1 
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9 epi 1 情境 1: JSP 的 环境 配置 与 开发 工具 
”测试 是 2 情境 2: Web 开 发 HTML 应 
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图 5-66 ”可 以 下 载 学 习 资料 的 页 面 2 


综合 练习 2 一 一 购物 网 站 


【题目 】 

制作 一 个 购物 网 站 ,要 求 网 站 的 系统 分 为 两 个 部 分 : 一 部 分 是 管理 员 的 后 台 管理 ; 另 一 
部 分 是 用 户 的 前 台 操 作 。 管 理 员 可 以 对 商品 的 库存 进行 管理 (添加 、 修 改 、 删 除 、 查 询 商品 )， 
还 可 以 查看 会 员 的 购物 订单 , 男 外 还 可 以 对 网 站 的 会 员 进 行 查看 或 删除 。 普 通用 户 浏览 这 


ae NE EO [ 情境 五 J5p 数 据 库 应 用 FON 


个 购物 网 站 的 时 候 可 以 查看 网 站 商品 的 库存 情况 ,如 果 想 要 购买 的 话 ,需要 先 注册 成 为 网 站 的 
会 员 , 然 后 才 可 以 把 商品 放 到 购物 车 中 ,确定 购买 之 后 可 以 提交 购物 车 中 的 商品 形成 订单 。 


【分 析 】 
购物 网 站 制作 要 求 及 内 容 如 图 5-67 所 示 。 
添加 图 书 bookadd.jsp 
修改 图 书 bookeditjsp 、bookeditl.jsp 、bookedit3.jsp 
图 书 管理 
删除 图 书 bookdelete.jsp 
查询 图 书 bookquery.jsp、bookquery1.jsp 
= Zn faze 
abii # Gil Morderdisplay.jsp 
: 订单 管理 
”| | 查看 用 户 
查看 用 户 
" 用 户 管理 a 
上 删除 用 户 
书 
店 
用 户 注册 userregister.jsp 
用 户 购书 purchasel.j ae i 
RME H S purchase! jsp 提交 订单 orderjsp 


cartmanage jsp 查看 购物 车 mycartjsp 删除 所 购 图 书 cartdeletejsp 


清空 购物 车 cartclear.jsp 


修改 用 户 信息 


图 5-67 购物 网 站 制作 要 求 及 内 容 


(1) 管理 员 模 板 mb. dwt. jsp; 管 理 员 页 面 manage. jsp 文件 可 以 显示 book 数据 表 的 
所 有 信息 ,如 图 5-68 所 示 。 
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图 5-68 ”管理 员 界面 设计 模板 


[ziedMf sp] m 


(2) 用 户 模 板 cart. dwt. jsp ,会员 登 录 以 后 cartmanage. jsp 页 面 可 以 显示 会 员 能 够 购 
买 的 所 有 书籍 ,如 图 5-69 所 示 。 


= 
m 


修改 会 员 信息 
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图 5-69 用 户 界 面 设计 模板 


(3) 建立 数据 库 , 如 图 5-70 一 图 5-74 所 示 o 


nE nvarchar 50 
ane nvarchar so 
| "me = author nvarchar 50 
t OW "admin" , (EE "bx publisher nvarchar 50 
type nvarchar so 
price nvarchar 50 
stock nvarchar 50 
图 5-70 管理 员 表 admin 图 5-71 书籍 库存 表 book 


nE varchar 10 ——— 
password varchar 15 ETETE B N 
nane varchar 15 t tt "userorder" , BE A 
ze mitar d WS 数据 类 型 | 长 度 | em 
address varchar 50 >E varchar 10 
code varchar 15 
username varchar 10 
tel varchar 20 Iday] ae 20 
email varchar 30 money Yarchar 20 
图 5-72 会员 注册 表 图 5-73 会员 订单 表 userorder 


© Wik “orderlist” , 4AA 


AS 数据 类 型 ES ARE 
nE varchar 10 
[user] varchar 20 
book varchar 30 
[sun] varchar 10 
money varchar 


图 5-74 订单 详细 信息 表 


表 |» 关系 “| 索引 / 键 | cock 约束 | 
RS orderlist 
选 定 的 关系 人 @) Q FK userorder_orderlist xl 
rew ERO) 
KREW: [FK userorder orderlist 
ERED THER D 
orderlist userorder 
id -Tia ^ 


* |W 关系 | 索引 / 键 | omc 约束 | 
me: customer 
EWR) $ FKuserorder_custoner 了 | 
rew 删除 QD 
KREW: FK userorder customer 
FRRO ARW 
customer userorder 
id <Tusernane ^ 


H 5-75 表 orderlist 与 表 userorder 的 关系 


【运行 效果 】 


图 5-76 3 customer 与 表 userorder 的 关系 


(1) 登录 界面 (图 5-77)index. html, 选 择 管理 员 或 用 户 的 身份 ,然后 输入 相应 的 用 户 
名 和 密码 ,管理 员 进 入 manage,jsp 页 面 ,用 户 进入 cartmanage. jsp 页 面 。 


© 管理 员 


© 用 户 


注册 


图 5-77 登录 界面 


(2) 管理 员 界 面 (图 5-78)manage. jsp 显示 book 数据 表 的 所 有 信息 。 
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四 书 管理 图 书 ID 图 书 名 称 作者 
anes 1 计算 机 基础 xx 
sams : ial z 
BREH 3 旅行 者 ss 
mam 4 绝对 小 孩儿 m 
5 网 络 技术 - 
6 瑜伽 tt 
s n 7 广告 创意 - 
Haea 8 JSP JSP 
删除 会 员 
操作 员 ，aaa 
时 间 ，2015-2-6 
返回 管理 员 首 页 
os 


xe 88 om IA BH Y - O X 

+|- > j| 句 | 图 - Qu 

A One 
出 版 社 类 别 du& o 库存 
高 教 出 版 社 科技 20 0 
上 海 科技 20 6 
上 海 科技 15 10 
文艺 出 版 社 科技 23 8 
人 民 邮电 出 版 社 科技 12 12 
人 民 邮 电 出 版 社 科技 34 6 
机 械 工业 出 版 社 科技 44 0 
JSP 科技 30 0 
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图 5-78 管理 员 界 面 manage. jsp 


Q 动态 网 站 设计 与 制作 一 JSP a 


(3) 管理 员 一 一 修改 图 书 (图 5-79 和 图 5-80) bookedit. jsp,bookeditl. jsp. 
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图 5-79 修改 图 书 1 
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His-80 修改 图 书 2 


(4) 管理 员 一 一 删除 图 书 (图 5-81)bookdelete. jsp. bookdeletel. jsp. 

(5) 管理 员 一 一 图 书 查询 (图 5-82 和 图 5-83) bookquery. jsp, bookqueryl. jsp. 

(6) 管理 员 对 订单 的 查看 、 删 除 核对 会 员 的 查看 删除 功能 与 图 书 的 查看 和 删除 
的 功能 实现 。 

(7) 会 员 注 册 (userregister. jsp 页 面 ) ,注册 为 会 员 ( 图 5-84) 以 后 就 能 够 从 登录 页 面 
index. html 进入 到 会 员 首 页 (图 5-85)。 
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图 5-82 ”查询 图 书 1 
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图 5-83 查询 图 书 2 


图 5-84 2 AEA userregister. jsp 
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网 ab 购 困 书 1 计算 机 基础 xx 高 教 出 版 社 o 20 购 天 
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图 5-85 用户 购买 首页 


(8) 在 用 户 首页 cartmanage. jsp 填写 购书 的 数量 ,并 单 击 “购买 ?按钮 , 执行 


parchase. jsp 代码 页 ,然后 跳 转 到 mycart. jsp 页 面 。 


(9) 购物 车 mycart. jsp 页 面 (图 5-86) 显 示 要 买 的 书籍 ,如 果 放 弃 可 以 单 击 * 清 空 购物 
车 cartclear. jsp? 或 者 “我 不 要 了 cartdelete. jsp”; 如 果 确 定 不 再 改动 单 击 “ 提 交 订 单 ” 执 行 


order. jsp, 然 后 跳 转 到 订单 页 面 rderdisplay. jsp. 


(10) 查看 订单 页 面 (图 5-87)orderdisplay. jsp . 单 击 “查看 ”可 以 跳 转 到 orderdetail. 


jsp 页 面 查看 订单 详细 信息 。 
QD 订单 详细 信息 页 面 (图 5-88)orderdetail. jsp. 


源 代码 见 附录 1. 
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图 5-86 ”购物 车 
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A rn -| 

WA 
1 ec 2011-5-18 40.0 aa 
2 ec 2011-5-18 46.0 查看 
3 ce 2011-5-18 24.0 查看 
4 ce 2011-5-18 24.0 查看 
5 ce 2011-5-18 24.0 xn 
6 ce 2011-5-18 15.0 查看 
13 ec 2015-2-6 60.0 查看 
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图 5-87 查看 订单 
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图 5-88 订单 详细 信息 


[mydb. java] 


本 文件 与 本 章 前 面 例题 中 的 代码 相同 ,只 是 在 连接 数据 库 的 语句 上 做 了 修改 , 源 代码 


如 附 图 1-1 所 示 。 
(cart. java] 


package bean; 
public class cart { 
private String bookId; 
private int num; 
public cart ( 
bookId=""; 
num=0; 
} 
public cart(String bookId, int num) { 
this. bookId— bookld ; 
this. num— num; 
) 
public String getBookId( ) { 
return( bookId) ; 
) 
public void setBookId(String booklId) ( 
this. bookId— booklId ; 
) 
public int getNum() f 
return( num) ; 
) 
public void setNum(int num) { 
this. num— num; 
) 
) 


index. html] 


<html > 
<head> 
<title> Ii </title> 
<style type="text/css"> 
<!-- 


S i bookshop | 
| 80 sre 
| 8 8 bean 
@ B) cart. java 
(000 8 D mydb. java 
| WmÀJRE System Library [yE 
, & Bi J2EE 1.4 Libraries 
| & $9 WebRoot 
| | BS cart 
if cartclear. jsp 


| cartdelete. jsp 


W orderdisplay. jsp 
if purchase. jsp 
if userregister. jsp 


| | | È bookdelete. jsp 
iP bookdeletel. jsp 
国 bookedit. jsp 
Wf bookeditl. jsp 
| AP bookquery. jsp 
WP bookqueryl. jsp 
| | manage. jsp 
(oo: C» XETA-INF 

| & © WEB-INF 

iP index. html 


附 图 1-1 源 代码 


.STYLE9 (font-family: Arial, Helvetica, sans-serif; font-size: 18px; } 


附录 1 源 代码 ] Ko» "M 


--> 
</style> 
</head> 
<body> 
<form id— "form5" name= "form5" method="post" action= "login. jsp"> 
<table width — "500" border ="0" align = 
bgcolor=" # 0099CC"> 
<> 


"center" cellpadding — "0" cellspacing — "2" 


<td height =" 50" colspan — "2" align="center" valign =" middle" bgcolor = 
"# FFFFFF"><label> 

<input name— "role" type="radio" id="radio" value= "manager" checked= "checked" /> 
<span class="STYLE9" > # </span> &-nbsp; &-nbsp; &-nbsp; 

<input type="radio" name="role" id— "radio2" value="user" /> 


<span class="STYLE9"> J P! </span></label> 
</td> 


</tr> 
<tr> 
<td width="203" align="right" valign="middle" bgcolor =" # FFFFFF" >< span 
class="STYLE9">ĦH P & :</span> </td> 
<td width — "394" height="50" valign="middle" bgcolor =" # FFFFFF">< label> 
&-nbsp; & nbsp; &-nbsp; &-nbsp; & nbsp; 
<input name= "username" type="text" id= "textfield" size="15" /> 
</label> 
</td> 
</tr> 
<tr> 
<td align="right" valign="middle" bgcolor=" # FFFFFF">< span class="STYLE9"> 
TB : </span> </td> 
<td height="50" valign="middle" bgcolor=" # FFFFFF"><label> &nbsp; &-nbsp; 
& nbsp; &nbsp; &-nbsp; 
<input name= "password" type="password" id= "textfield2" size="15" /> 
</label> 
</td> 
</tr> 
<tr> 


<td height="50" colspan="2" align="center" valign="middle" bgcolor=" # FFFFFF"> 
<label> 


<input type="submit" name="button" id— "button" value 一 "登录 " /二 
</label> 
<label> &nbsp; & nbsp; & nbsp; 
<input type="reset" name="button2" id="button2" value 一 "取消 " /> 
</label> 
</td> 
</tr> 
<tr> 


<td height="50" colspan="2" align="center" valign="middle" bgcolor=" # FFFFFF" 


class="STYLE9"><a href= "cart/ userregister. jsp" > iE M</a ></td> 
</tr> 


</table> 


> [ 动态 网 站 设计 Si 一 sp] 0000 


</form> 
</body> 
</html> 


Login. jsp] 


<%@ page content Type — "text/html; charset—gb2312" language="java" import="java. sql. * " %> 
<html> 
<body> 
<jsp:useBean id— "db" class— "bean. mydb" scope="page"/> 
<% 
String username= request. getParameter( "username" ) ; 
String password request. getParameter( " password" ) ; 
String role— request. getParameter("role") ; 
ResultSet rs— null; 
// 如 果 是 管理 员 页 面 跳 转 到 管理 页 面 
if (role. equals("manager")) 
{ 
db. connection() ; 
rs— db. query(" SELECT * FROM admin WHERE id=" +"\'" + username - "V '" + 
"AND password " -- "V'" -- password-- "V'") ; 
while(rs. next() ) 
{ 
session. setAttribute(" username" , username) ; 
response. sendRedirect( " manage/manage. jsp") ; 
) 
) 
// 如 果 是 用 户 页 面 跳 转 到 用 户 页 面 
if(role. equals(" user") ) 
{ 
db. connection() ; 
rs—db.query(" SELECT * FROM customer WHERE id="+"\'"+username+"\"" 
+ "AND password — " - "V'" +password+"\'"); 
while(rs. next()) 
{ 
session. setAttribute(" username" , username) ; 
response. sendRedirect("cart/cartmanage. jsp") ; 
) 
) 
%> 
</body> 
</html> 


[manage. jsp] 


<%@ page contentType= "text/html; charset=gb2312" language= "java" import= "java. sql. * , 
java. util. * " errorPage—"" 947» 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www. 
w3.org/ TR/ xhtml1/DTD/ xhtmll-transitional. dtd" > 

<html xmlns =" http://www. w3. org/1999/xhtml" > <!- - InstanceBegin template = 


附录 1 源 代码 ] OA _| 


"/Templates/mb. dwt. jsp" codeOutsideHTMLIsLocked= "false" --> 
<head> 
<meta http-equiv— "Content-Type" content= "text/html; charset=gb2312" /> 
<!-- InstanceBeginEditable name= "doctitle" --> 
<title> FBR </title> 
<!-- InstanceEndEditable --> 
<!-- InstanceBeginEditable name— "head" --> 
<style type="text/css"> 
<l-- 
.STYLE14 {color: # FF6600} 
.STYLE18 (font-size: 24} 
-=--> 
</style> 
<!-- InstanceEndEditable --> 
<style type="text/css"> 
<!-- 
.STYLE10 (font-family: "宋体 "} 
.STYLE12 (font-family: Arial, Helvetica, sans-serif; font-size: 16px; } 
.STYLE2 (font-family: "XIT"; 
font-size: 24px; 
color: # FF9900; 
} 
--> 
</style> 
</head> 
<jsp:useBean id="db" class= "bean. mydb" scope= "page" /> 
<body> 
<table width="900" border="0" align="center" cellpadding= 
<tr> 
<td width="149" height= "40" — span class="STYLE2"> [8 45€ 3l — / span </td> 
<td width =" 751" rowspan =" 10" align =" center" valign =" top" > <!- - 
InstanceBeginEditable name— "EditRegion3" --> 
<form id— "forml1" name— "forml" method="post" action=""> 
<table width— "700" border— "0" cellspacing— "0" cellpadding="0"> 
<tr> 
<td height="30" align="center" valign="middle" bgcolor=" # CCCCCC"> 
<span class="STYLE10 STYLE18">&-nbsp; Al 3 ID</span></td> 
<td height="30" align="center" valign="middle" bgcolor =" #CCCCCC"> 
<span class= "STYLE10 STYLE18" >A 45 4 ff &-nbsp;</span></td> 
<td height="30" align="center" valign="middle" bgcolor=" # CCCCCC"> 
<span class 一 "STYLE10 STYLE18">(F# &nbsp;</span></td> 


cellspacing="0"> 


<td height="30" align="center" valign="middle" bgcolor =" # CCCCCC"> 
<span class 一 "STYLE10 STYLE18"> ih fitt. &nbsp;</span></td> 
<td height="30" align="center" valign="middle" bgcolor=" # CCCCCC"> 


<span class="STYLE10 STYLE18" > $l] &-nbsp;</span></td> 
<td height="30" align="center" valign="middle" bgcolor=" # CCCCCC"> 
<span class="STYLE10 STYLE18">ft# &nbsp;</span></td> 
<td height="30" align="center" valign="middle" bgcolor=" # CCCCCC"> 
<span class 一 "STYLE10 STYLE18">/#%f &nbsp;</span></td> 
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<td height="30" align="center" valign="middle" bgcolor— " # CCCCCC" > 
<span class= "STYLE18"></span></td> 
</tr> 
< 
ResultSet rs=null; 
db. connection() ; 
String query="select * from book"; 
rs— db. query(query) ; 
while (rs. next()) 
( String sl— rs. getString(1) ; 
String s2— rs. getString(2) ; 
String s3— rs. getString(3) ; 
String s4— rs. getString(4) ; 
String s5— rs. getString(5) ; 
String s6— rs. getString(6) ; 
String s7 —rs. getString(7) ; 
%> 
<tr> 
<td height — "30" align="center" valign =" middle" — < span class = 
"STYLE18" ><% =s1% ></span> </td> 
<td height = "30" align="center" valign =" middle" > < span class = 
"STYLE18" ><% — 524 ></span> </td> 
<td height — "30" align="center" valign =" middle" — < span class = 
"STYLE18" ><% =s3% ></span> </td> 
<td height — "30" align="center" valign =" middle" >< span class = 
"STYLE18" ><% =s4% ></span> </td> 
<td height ="30" align="center" valign =" middle" > < span class = 
"STYLE18" ><% — 5 4 ></span> </td> 
<td height — "30" align="center" valign =" middle" > < span class = 
"STYLEI8"7 «96 — 564 ></span> </td> 
<td height — "30" align="center" valign="middle" ><span class = 
"STYLE18"><%=s7 %></span></td> 
</r><% } %> 
</table> 
</form> 
<!-- InstanceEndEditable --></td> 
</tr> 
<tr> 
<td height="30" align="center" bgcolor=" # FFCC66">< span class="STYLE12"> 
<a href="bookadd. jsp" > 1 Jlll [El 5 </a ></span> </td> 
</tr> 
<tr> 
<td height="30" align="center" bgcolor=" € FFCC66">< span class= "STYLE12"> 
<a href="bookedit. jsp" > f it [E] B</a></span></td> 
</tr> 
<tr> 
<td height="30" align="center" bgcolor=" # FFCC66">< span class="STYLE12"> 
<a href="bookdelete. jsp" > MIRE </a ></span> </td> 
</tr> 
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<tr> 
<td height="30" align="center" bgcolor=" # FFCC66">< span class="STYLE12"> 
<a href="bookquery. jsp" > # ifj El 3 </a ></span> </td> 
</tr> 
<u> 
<td height="40" class= "STYLE2"> 0 ŽE </td> 
</tr> 
<tr> 
<td height="40" class="STYLE2">2 R FH</td> 
</tr> 
<tr> 
<td height— "30" align="center" bgcolor=" # FFCC66" class="STYLE12">#i& 
fid 
</tr> 
xu 
<td height— "30" align="center" bgcolor=" # FFCC66" class— "STYLE12"> JI B 
员 一 /td> 
</tr> 
<% 
GregorianCalendar d= new GregorianCalendar( ) ; 
String year= Integer. toString(d. get(Calendar. YEAR) ) ; 
String month= Integer. toString(d. get(Calendar. MONTH) +1); 
String day = Integer. toString(d. get(Calendar. DAY_OF_MONTH)); 
%> 
<tr> 
<td height — "60" align — " center" ><span class =" STYLE10" > # fF A: <% = 
(String) session. getAttribute("username") % ><br /> 
BY fA]: <% = year% >-< % =month% >-< % =day% ></span> </td> 
</tr> 
<tr> 
<td height="30" align="center" ><a href= "manage. jsp" >36 [n] H 5 1$ </a> 
</td> 
</tr> 
</table> 
</body> 
<!-- InstanceEnd --></html> 


[bookadd. jsp] 


<%@ page contentType— "text/html; charset— gb2312" language— "java" import— "java. sql. * , 
java. util. * " errorPage— "" 267 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www. 
w3.org/ TR/xhtml1/DTD/xhtmll-transitional. dtd" > 


<html xmlns =" http://www. w3. org/1999/xhtml" > <!- - InstanceBegin template = 
"/Templates/mb. dwt. jsp" codeOutsideHTMLIsLocked— "false" --> 
<head> 


<meta http-equiv— "Content-Type" content— "text/html; charset= gb2312" /> 
<!-- InstanceBeginEditable name= "doctitle" --> 
<title> 6 bg Bl </title> 
<!-- InstanceEndEditable --> 
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<!-- InstanceBeginEditable name="head" --> 
<style type="text/css"> 
<l-- 
.STYLE19 (font-family: "宋体 "; font-size: 16; } 
.STYLE19 {font-family: Arial, Helvetica, sans-serif; font-size: 16px; } 
a 
</style> 
<!-- InstanceEndEditable --> 
<style type="text/css"> 


<{-- 
.STYLE14 (color: # FF6600} 
.STYLE18 {font-size: 24} 
--> 
</style> 
<style type="text/css"> 
<!-- 
.STYLE10 (font-family: "宋体 "} 
.STYLE12 (font-family: Arial, Helvetica, sans-serif; font-size: 16px; } 
.STYLE2 (font-family: "46 C47 ##"; 
font-size: 24px; 
color: #FF9900; 
) 
--> 
</style> 
</head> 
<jsp:useBean id="db" class= "bean. mydb" scope="page"/> 
<body> 
<table width= "900" border="0" align="center" cellpadding= "0" cellspacing= "0"> 
<tr> 
<td width="149" height="40" ><span class= "STYLE2"> 3 $38 </span></td> 


< td width =" 751" rowspan =" 10" align =" center" valign =" top" > <!- - 

InstanceBeginEditable name— "EditRegionl" --> 

<form id— "form1" name= "form1" method="post" action— ""— 

<table width— "500" border— "0" align="center" cellpadding 

<tr> 

< td height =" 30" colspan — "2" align =" left" valign =" middle" bgcolor = 
"#CCCCCC" class= "STYLE7" >< label> < span class =" STYLE10" > [8 3 4t 
HDE mE B</span></label ></td> 


" cellspacing= "0"> 


</tr> 

<tr> 
<td height="15" align="right" valign="middle" class= "STYLE? STYLE8"> [8 55 
ID: </td> 


<td height="30" align="left" valign="middle" ><input name = " bookid" type= 
"text" id— "textfield" /></td> 

</tr> 

<u> 
<td height="30" align="right" valign="middle" class 一 "STYLE7 STYLE8"> HË 
BR: </td> 
<td height="30" align="left" valign="middle" ><span class="STYLE19"> 


P [wz 源 代码 ] KD. | 


<label> 
<input type="text" name— "bookname" id= "textfield2" /> 
</label> 
</span></td> 
</tr> 
<tr> 
<td height="30" align="right" valign="middle" class 王 "STYLE7 STYLE8" >% 
#:</td> 
<td height— "30" align="left" valign="middle" ><span class="STYLE19"> 
<label> 
<input type="text" name="author" id— "textfield3" /> 
</label> 
</span></td> 
</tr> 
xu 
<td height— "30" align="right" valign="middle" class- "STYLE? STYLE8"> th flit 
db: </td> 
<td height— "30" align="left" valign="middle" ><span class— "STYLE19"— 
<label> 
<input type="text" name= "publisher" id= "textfield4" /> 
</label> 
</span></td> 
</tr> 
<tr> 
<td height="30" align="right" valign="middle" class="STYLE7 STYLE8" >% 
Bs </td> 
<td height="30" align="left" valign="middle" ><span class="STYLE19"> 
<label> 
<select name= "category" id="select" > 
<option selected= "selected" > #}4% </option> 
<option> % A</option> 
«option /E i </option> 
<option>#t 4 — / option 
<option> # /& </option> 
<option># A </option> 
</select> 
</label> 
</span></td> 
</tr> 
<tr> 
<td height="30" align="right" valign="middle" class 一 "STYLE7 STYLE8"> ffr 
Tí </td> 
<td height="30" align="left" valign="middle" ><span class="STYLE19"> 
<label> 
<input type="text" name="price" id= "textfield5" /> 
</label> 
</span></td> 
</tr> 
<u> 


Q CA 


<td height="30" align="right" valign="middle" class="STYLE7 STYLES"- JE 
存 : 一 /td> 
<td height="30" align="left" valign="middle" ><span class= "STYLE19"> 
<label> 
<input type="text" name="stock" id— "textfield6" /> 
</label> 
</span></td> 
</tr> 
<u> 
<td height="30" colspan="2" align="center" valign="middle" ><label> 
<input type="submit" name="button" id="button" value 一 "确定 " /> 
</label> 
<label> 
<input type= "reset" name="button2" id="button2" value— "3E Hi" /> 
</label></td> 
</tr> 
<% 
// 获 取 表 单 提交 数据 
String bookid=db. hzsb(request. getParameter("bookid")) ; 
String bookname- db. hzsb( request. getParameter("bookname")) ; 


String author— db. hzsb( request. getParameter("author")) ; 
String publisher— db. hzsb( request. getParameter(" publisher") ) ; 
String category — db. hzsb(request. getParameter( category") ) ; 
String price— db. hzsb( request. getParameter("price")) ; 

String stock— db. hzsb( request. getParameter( " stock") ) ; 


// 如 果 数 据 都 不 为 空 ,插入 数据 库 book 表 中 
if (bookid! — null & & bookname! — null &-&- author! — null &-& publisher! — null & &. 
category! — null 88. price! — null && stock! = null) 
{ 
String rssql= "insert into book values" 4- "V" + bookid+"\"-+", " - "V" 4- bookname 
PAE n nx I" Egathor-- "N36-p 8," E»Vin-Engblisher-F "N98 4-7, n ror 
NE prices E NI" En, 9 NE stock PX dy 


db. connection) ; 


int rsn— db. update(rssql) ; 
if (rsn>0) 
response. sendRedirect(" manage. jsp") ; 
) 
%> 
</table> 
</form> 
<!-- InstanceEndEditable --></td> 
</tr> 
<tr> 
<td height — "30" align="center" bgcolor =" # FFCC66" >< span class =" STYLE12"> 
<a href=" bookadd. jsp" > if in El B — / a7 </span> </td> 
</tr> 
<u> 
<td height="30" align="center" bgcolor ="  FFCC66" ><span class= "STYLE12"> 


<a href="bookedit. jsp" > f A B </a></span></td> 
</tr> 
<tr> 
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<td height="30" align="center" bgcolor =" # FFCC66" ><span class =" STYLE12"> 


<a href="bookdelete. jsp" > MRE B </a> </span> </td> 
</tr> 
<tr> 


<td height —"30" align — "center" bgcolor =" € FFCC66" — — span class =" STYLE12"> 


<a href="bookquery. jsp"># ifi] A B — / a7 — / span </td> 
</tr> 
<tr> 

<td height="40" class="STYLE2">i] 4% #</td> 
</tr> 
<tr> 

<td height="40" class="STYLE2">2 ft  #</td> 
</tr> 
<u> 


<td height="30" align="center" bgcolor=" # FFCC66" class= "STYLEI2"7 t ifj e fi </td> 


</tr> 
<tr> 
<td height= 
</tr> 
<% 
GregorianCalendar d= new GregorianCalendar( ) ; 
String year= Integer. toString(d. get(Calendar. YEAR) ) ; 
String month= Integer. toString(d. get(Calendar. MONTH) +1); 
String day — Integer. toString(d. get(Calendar. DAY_OF_MONTH)); 
%> 


<tr> 


0" align="center" bgcolor=" # FFCC66" class="STYLE12"> MRR </td> 


<td height —"60" align — " center" ><span class=" STYLE10" >$ fF Bi : <% = (String) 


session. getAttribute(" username") % ><br /> 


Bf fi] : << % = year% >-< % = month% >-< % = day 6 ></span> </td> 


</tr> 
<tr> 


<td height="30" align— "center" ><a href= "manage. jsp" >3& [nl £38 R 1$ </a></td> 


</tr> 
</table> 


</body> 
<!-- InstanceEnd --></html> 


[bookdelete. jsp] 


<%@ page contentType 
java. util. * " errorPage="" 547» 


text/html; charset— gb2312" language— "java" import="java. sql. * , 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www. 


w3.org/ TR/xhtml1/DTD/ xhtmll-transitional. dtd" > 


<html xmlns =" http://www. w3. org/1999/xhtml" > <!- - InstanceBegin template = 


"/Templates/mb. dwt. jsp" codeOutsideHTMLIsLocked— "false" --> 


Q (semwmirsst ue] 0 00 


<head> 
<meta http-equiv— "Content-Type" content="text/html; charset=gb2312" /> 
<!-- InstanceBeginEditable name= "doctitle" --> 
<title> HRA B</title> 
<!-- InstanceEndEditable --> 
<!-- InstanceBeginEditable name= "head" --> 
<style type="text/css"> 
<!-- 
.STYLE14 {color: # FF6600} 
.STYLE18 (font-size: 24} 
--> 
</style> 
<!-- InstanceEndEditable --> 
<style type="text/css"> 


<I-- 
.STYLE10 (font-family: "宋体 "} 
.STYLE12 (font-family: Arial, Helvetica, sans-serif; font-size: 16px; } 
.STYLE2 (font-family: "XTR"; 
font-size: 24px; 
color: # FF9900; 
) 
--> 
</style> 
</head> 
<jsp:useBean id="db" class= "bean. mydb" scope="page"/> 
<body> 
<table width="900" border="0" align="center" cellpadding= "0" cellspacing= "0"> 
<tr> 
<td width="149" height="40" ><span class= "STYLE2"> El BE 38 — / span» </td> 
< td width =" 751" rowspan =" 10" align =" center" valign =" top" > <!- - 


InstanceBeginEditable name— "EditRegion3" --> 
<form id— "forml1" name— "forml" method="post" action— ""— 
<table width — "700" border— "0" cellspacing— "0" cellpadding="0"> 
<tr> 
<td height — "30" align="center" valign="middle" bgcolor =" # CCCCCC" > 
<span class="STYLE10 STYLE18">&-nbsp; 43 ID</span></td> 
<td height ="30" align="center" valign="middle" bgcolor =" # CCCCCC" > 
<span class="STYLE10 STYLEI18"— [8 34 f& & nbsp; </span></td> 
<td height — "30" align="center" valign="middle" bgcolor =" # CCCCCC" > 
<span class="STYLE10 STYLE18">{€# &nbsp;</span></td> 
<td height — "30" align="center" valign="middle" bgcolor =" € CCCCCC" > 
"STYLE10 STYLE18"> Hi itt. &nbsp;</span></td> 
<td height="30" align="center" valign="middle" bgcolor =" # CCCCCC" > 
<span class="STYLE10 STYLE18">X j| &nbsp;</span></td> 
<td height="30" align="center" valign="middle" bgcolor =" € CCCCCC" > 
<span class 一 "STYLE10 STYLE18"> ft &nbsp;</span></td> 
<td height="30" align="center" valign="middle" bgcolor =" € CCCCCC" > 
<span class 一 "STYLE10 STYLE18"> FE &nbsp;</span></td> 
<td height — "30" align="center" valign="middle" bgcolor =" € CCCCCC" > 


<span clas: 


< 


Mai 源 代码 ] 


<span class="STYLE18" ></span></td> 


</tr> 
<% 

ResultSet rs=null; 
db. connection() ; 

String query=" 

rs— db. query(query) ; 

while (rs. next()) 

{ String sl=rs 

String s2=rs 

String s3— rs 


. getString(1); 
.getString(2) ; 
.getString(3) ; 
-getString(4) ; 
.getString(5) ; 
.getString(6) ; 
.getString(7) ; 


String s4— rs 
String s5—rs 
String s6— rs 
String s7=rs 
5n 
<tr> 
<td height= "30" align="center" 
<% =s1% ></span> </td> 
<td height= "30" align="center" 
<% =s2% ></span> </td> 
<td height="30" align="center" 
<% =s3% ></span> </td> 
<td height= "30" align="center" 
<%=s4%></span> </td> 
<td height="30" align="center" 
<%=s5% ></span></td> 
<td height="30" align="center" 
<%=s6%></span></td> 
<td height="30" align="center" 
<%=s7%></span></td> 


=" 


select * from book"; 


valign="middle" ><span class= "STYLE18"> 
valign="middle" ><span class= "STYLE18"> 
valign="middle" ><span class= "STYLE18"> 
valign="middle" ><span class= "STYLE18"> 
valign="middle" ><span class= "STYLE18"> 
valign="middle" ><span class= "STYLE18"> 


valign="middle" ><span class= "STYLE18"> 


<td height="30" align="center" valign="middle" ><span class= "STYLE10 
STYLE18"><span class="STYLE14" ><a href=" bookdeletel . jsp? id=<% = 
sl %>"> MW R</a></span>&nbsp;</span></td> 


</tr><% } 5 
/table> 


</form> 


<% 


String id= request. getParameter("id") ; 


if 
{ 


Cid! =null) 


String sq_l="DELETE FROM book WHERE id="+"\'"+id+"\'""; 
db. connection() ; 
db. delete(sql) ; 

response. sendRedirect( " bookdelete. jsp") ; 


) 
%> 


<!-- InstanceEndEditable --></td> 


</tr> 
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<u> 
<td height="30" align="center" bgcolor=" # FFCC66" ><span class= "STYLE12"><a 
href= "bookadd. jsp" > #8 hil Al </a></span></td> 
</tr> 
<tr> 
<td height="30" align="center" bgcolor=" # FFCC66"><span class= "STYLE12"><a 
href= "bookedit. jsp" > it RB </a></span> </td> 
</tr> 
<tr> 
<td height="30" align="center" bgcolor=" # FFCC66">< span class= "STYLE12"><a 
href= "bookdelete. jsp" > WA B </a></span> </td> 
</tr> 
<tr> 
<td height="30" align="center" bgcolor=" # FFCC66" ><span class="STYLE12" ><a 
href= "bookquery. jsp" > # if] Al B </a></span></td> 
</tr> 
<tr> 
<td height="40" class= "STYLE2"- iT (4% </td> 
</tr> 
<tr> 
<td height="40" class="STYLE2">2 RE PE — /td— 
</tr> 
<tr> 
<td height="30" align="center" bgcolor=" # FFCC66" class="STYLE12"> # iJ e fà </td> 
</tr> 
<tr> 
<td height="30" align="center" bgcolor=" # FFCC66" class="STYLE12"> fH RZ fA </td> 
</tr> 
<% 
GregorianCalendar d= new GregorianCalendar() ; 
String year= Integer. toString(d. get(Calendar. YEAR) ) ; 
String month= Integer. toString(d. get(Calendar. MONTH) +1); 
String day = Integer. toString(d. get(Calendar. DAY OF MONTH)); 
%> 
<tr> 
<td height — "60" align — "center" ><span class =" STYLE10" >$ fF A : <% = (String) 
session. getAttribute(" username") % ><br /> 
Bef [B] : <% = year% >-< % = month% >-< % = day 6 ></span> </td> 
</tr> 
<tr> 
<td height="30" align= "center"><a href= "manage. jsp" >36 [n] 438 f 1$ </a></td> 
</tr> 
</table> 
</body> 
<!-- InstanceEnd --></html> 


[bookdeletel. jsp] 


<%@ page contentType- "text/html; charset— gb2312" language— "java" import="java. sql. * , 
%> 


java.util. * " errorPage 


WRI 源 代码 ] Ke _| 


<html> 
<head></head> 
<body> 
<jsp:useBean id="db" class— "bean. mydb" scope="page"/> 
<% 
String id= request. getParameter("id") ; 
if (id! =null) 
{ 
String sql="DELETE FROM book WHERE id="+"\""+id+"\'""; 
db. connection() ; 
db. delete(sql) ; 
response. sendRedirect( " bookdelete. jsp") ; 
) X 
</body> 
</html> 


【bookedit. jsp] 


<%@ page contentType= "text/html; charset=gb2312" language= "java" import="java. sql. * , 
java. util. * " errorPage="" %> 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www. 
w3.org/ TR/ xhtmll/DTD/ xhtmll-transitional. dtd" > 
<html xmlns =" http://www. w3. org/1999/xhtml" > <!- - InstanceBegin template = 
"/Templates/mb. dwt. jsp" codeOutsideHTMLIsLocked= "false" --> 
<head> 
<meta http-equiv="Content-Type" content— "text/html; charset=gb2312" /> 
<!-- InstanceBeginEditable name= "doctitle" --> 
<title> Fe bs BH </title> 
<!-- InstanceEndEditable --> 
<!-- InstanceBeginEditable name= "head" --> 
<!-- InstanceEndEditable --> 
<style type="text/css"> 
<!-- 
.STYLE14 (color: #FF6600} 
.STYLE18 (font-size: 24) 
--> 
</style> 
<style type="text/css"> 
<!-- 
.STYLE10 (font-family: "Af&") 
.STYLEI2 (font-family: Arial, Helvetica, sans-serif; font-size: 16px; } 
.STYLE2 (font-family: "华文 行 楷 "; 
font-size: 24px; 
color: # FF9900; 
} 
--> 
</style> 
</head> 
<jsp:useBean id="db" class= "bean. mydb" scope="page"/> 
<body> 


Cy [动态 网 站 设计 Ss 制 和 一 J5P] 7 m 


<table width="900" border="0" align="center" cellpadding= 


<u> 


cellspacing— "0" > 


<td width="149" height="40"><span class= "STYLE2">A 5 #38</span></td> 
< td width =" 751" 
InstanceBeginEditable name="EditRegion1" --> 

<form id="form1" name="form1" method="post" action=""> 
<table width="700" border— "0" cellspacing— "0" cellpadding="0"> 


<tr> 


rowspan =" 10" align =" center" valign =" top" > <!- - 


<td height="30" align="center" valign="middle" bgcolor=" # CCCCCC" ><span 


class= "STYLE10 STYLE18"> &nbsp; 


# ID</span></td> 


<td height="30" align="center" valign="middle" bgcolor=" # CCCCCC">< span 
class="STYLE10 STYLE18"> [£l 95 & f &nbsp; </span> </td> 
<td height="30" align="center" valign="middle" bgcolor=" # CCCCCC" ><span 
class="STYLE10 STYLE18">{€# &-nbsp; </span> </td> 
<td height="30" align="center" valign="middle" bgcolor=" € CCCCCC"> <span 
class="STYLE10 STYLE18"> Hitt &-nbsp;</span></td> 
<td height="30" align="center" valign="middle" bgcolor=" # CCCCCC" ><span 
class="STYLE10 STYLE18"> Hi] & nbsp; </span> </td> 
<td height="30" align="center" valign="middle" bgcolor=" € CCCCCC"> <span 
class="STYLE10 STYLE18"> fft fit &nbsp;</span></td> 
<td height="30" align="center" valign="middle" bgcolor =" # CCCCCC">< span 
class="STYLE10 STYLE18">J# f£. &-nbsp;</span></td> 
<td height="30" align="center" valign="middle" bgcolor=" # CCCCCC" ><span 
class= "STYLE18"></span></td> 

</tr> 


«n 


ResultSet rs— null; 
db. connection) ; 


String query— "select * from book"; 


rs— db. query(query) ; 
while (rs. next() ) 
(String s1— rs. getString(1) ; 


“> 
<tr> 
<td height= "30" 


String s2 


String s3 


String s4=rs 
String s5— rs 
String s6— rs 
String s7— rs 


- getString(2) ; 


s. getString(3) ; 


- getString(4) ; 
-getString(5) ; 
. getString(6) ; 
.getString(7) ; 


align="center" valign— " middle" 7» 8 nbsp; 9 =s1% ></td> 
"center" valign— "middle" &-nbsp; <% =s2% ></td> 
"center" valign— "middle" & nbsp; < % —53 96 ></td> 
"center" valign— "middle" 7 & nbsp; < 94 =s4% ></td> 
align="center" valign— " middle" > 8- nbsp; < 9 =s5% ></td> 


<td height— "30" align="center" valign— " middle" 7 &-nbsp;<% =s6% ></td> 


<td height= 


"30" align="center" valign= "middle"> &-nbsp; < % =s7 % ></td> 


<td height =" 30" align="center" valign = " middle" >< span class = "STYLE10 


STYLE18">< span class = 


STYLE14" ><a href =" bookeditl. jsp? id = <% = 
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s1%>" > Bt / a7 — / span? & nbsp; </span> </td> 
</tr> 
<% } %> 
</table> 
</form> 
<!-- InstanceEndEditable --></td> 
</tr> 
<tr> 
<td height="30" align="center" bgcolor=" # FFCC66" ><span class=" STYLE12" ><a 
href= "bookadd. jsp" > Rm AB </a></span></td> 
</tr> 
<tr> 
<td height="30" align="center" bgcolor=" # FFCC66">< span class= "STYLE12"><a 
href= "bookedit. jsp" 7 f& AB </a ></span> </td> 
</tr> 
<tr> 
<td height="30" align="center" bgcolor=" € FFCC66">< span class= "STYLE12"><a 
href= "bookdelete. jsp" > MRE B — /a7 — / span? </td> 
</tr> 
<tr> 
<td height— "30" align="center" bgcolor=" # FFCC66" ><span class=" STYLE12" ><a 
href= "bookquery.jsp" ># if] A 43 </a></span> </td> 
</tr> 
<tr> 
<td height="40" class="STYLE2">i] 1% </td> 
</tr> 
<tr> 
<td height="40" class="STYLE2">2 R E</td> 
</tr> 
<tr> 
<td height="30" align="center" bgcolor=" # FFCC66" class="STYLE12"># if] 2 </td> 
</tr> 
<tr> 
<td height="30" align="center" bgcolor=" i£ FFCC66" class="STYLE12">H RZ </td> 
</tr> 
<% 
GregorianCalendar d=new GregorianCalendar() ; 
String year= Integer. toString(d. get(Calendar. YEAR)); 
String month= Integer. toString(d. get(Calendar. MONTH) +1); 
String day— Integer. toString(d. get(Calendar. DAY OF MONTH)); 
%> 


<u> 
<td height —"60" align — " center" ><span class="STYLE10"> #8 fF fi: <% = (String) 
session. getAttribute("username") % ><br /> 
Bef [B] : <% = year % >-< % =month% >-< % = day % ></span> </td> 
</tr> 
<u> 
<td height= 


0" align= "center" ><a href="manage. jsp" 3E [Fl EE E 51 </a></td> 


O (asmenis weise] 0 00 


</tr> 
</table> 


</body> 
<!-- InstanceEnd --></html> 


[bookedit1. jsp] 


— 94 (8 page contentType= "text/html; charset— gb2312" language— "java" import="java. sql. * , 
java. util. * " errorPage-"" 547 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www. 
w3.org/ TR/xhtml1/DTD/xhtmll-transitional. dtd" — 
< html xmlns =" http://www. w3. org/1999/xhtml" > <!- - InstanceBegin template = 
"/Templates/mb. dwt. jsp" codeOutsideHTMLIsLocked= "false" --> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset—gb2312" /> 
<!-- InstanceBeginEditable name="doctitle" --> 
<title> bg Bl 3C Pj </title> 
<!-- InstanceEndEditable --> 
<!-- InstanceBeginEditable name= "head" --> 
<style type="text/css"> 
<!-- 
.STYLE19 (font-family: "宋体 "; font-size: 16; } 
.STYLE19 (font-family: Arial, Helvetica, sans-serif; font-size: 16px; ) 
— 
</style> 
<!-- InstanceEndEditable --> 
<style type="text/css"> 
<!-- 
.STYLE14 {color: # FF6600} 
.STYLE18 (font-size: 24} 
--> 
</style> 
<style type="text/css"> 
<!-- 
.STYLE10 (font-family: "宋体 ") 
.STYLE12 {font-family: Arial, Helvetica, sans-serif; font-size: 16px; } 
.STYLE2 (font-family: "XTR" ; 
font-size: 24px; 
color: # FF9900; 
} 
a 
</style> 
</head> 
<jsp:useBean id="db" class— "bean. mydb" scope="page"/> 
<body> 
<table width="900" border— "0" align="center" cellpadding="0" cellspacing="0"> 
<u> 
<td width="149" height="40" ><span class="STYLE2"> [E 5 Fl </span></td> 
< td width =" 751" rowspan =" 10" align =" center" valign =" top" > <!- - 
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InstanceBeginEditable name="EditRegion1" --> 
<form id="form1" name="form1" method="post" action= ""> 
<table width="500" border="0" align="center" cellpadding= 
<tr> 
< td height =" 30" colspan — "2" align =" left" valign =" middle" bgcolor = 
"#CCCCCC" class= "STYLE7" >< label >< span class =" STYLE10" > 45 # 
HB) 2 B </span> — / label — / td 
</tr> 
<% 
String id= request. getParameter("id") ; 
ResultSet rs— null; 
if (id! — null) 
{// 变 量 sql 存放 查询 语句 ,按照 id 查询 数据 库 表 
String sql 一 "SELECT * FROM book WHERE id= "+id+"; 
//3$ & db 调用 connection 方法 ,连接 数据 库 
db. connection() ; 
// 对 象 db 调用 query 方法 ,参数 为 “按照 id 查询 数据 库 表 ” 
rs— db. query(sql) ; 
while (rs.next()) { 
// 提 取 要 修改 的 详细 信息 
String sl=rs. getString(1) ; 


cellspacing="0"> 


String s2— rs. getString(2) ; 
String s3— rs. getString(3) ; 
String s4— rs. getString(4) ; 
String s6— rs. getString(6) ; 
String s7=rs. getString(7) ; 
“> 
<tr> 
<td height="15" align="right" valign="middle" class="STYLE7 STYLE8"> [E 4$ 
ID:</td> 
<td height="30" align="left" valign="middle" ><input name = " bookid" type= 
"text" id="textfield" value="<% =s1% >"/></td> 
</tr> 
<tr> 
<td height="30" align="right" valign="middle" class="STYLE7 STYLE8"> [E 4$ 
RR </td> 
<td height="30" align="left" valign="middle" ><span class="STYLE19"> 
<label> 
<input type="text" name="bookname" id="textfield2" value="<%=s2% >"/> 
</label> 
</span></td> 
</tr> 
<tr> 
<td height="30" align="right" valign="middle" class="STYLE7 STYLE8"> ff 
</td> 
<td height="30" align="left" valign="middle" ><span class="STYLE19"> 
<label> 
<input type="text" name= "author" id= "textfield3" value— "— 6 =s3% >"/> 
</label> 
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</span></td> 
</tr> 
<u> 
<td height="30" align="right" valign="middle" class 一 "STYLE7 STYLE8"> th fifi 
th: </td> 
<td height="30" align="left" valign="middle" ><span class="STYLE19"> 
<label> 
<input type="text" name= "publisher" id= "textfield4" value="<% =s4% >"/> 
</label> 
</span></td> 
</tr> 
<tr> 
<td height="30" align="right" valign="middle" class="STYLE7 STYLE8" >% 
Bs </td> 
<td height="30" align="left" valign="middle" ><span class= "STYLE19"> 
<label> 
<select name= "category" id="select"> 
<option selected— "selected" — fH — /option 


<option> #% #</option> 
«option Æ ii </option> 
<option>#t @</option> 
<option> 8 ik </option> 
<option>#& ff </option> 
</select> 
</label> 
</span></td> 
</tr> 
<tr> 
<td height="30" align="right" valign="middle" class="STYLE7 STYLE8"> ff 
fi </td> 
<td height="30" align="left" valign="middle" ><span class= "STYLE19"> 
<label> 
<input type="text" name= "price" id= "textfield5" value="<%=s6%>"/> 
</label> 
</span></td> 
</tr> 
<tr> 
<td height="30" align="right" valign="middle" class="STYLE7 STYLES8"- JE 
#:</td> 
<td height="30" align="left" valign="middle" ><span class="STYLE19"> 
<label> 
<input type="text" name="stock" id="textfield6" value="<%=s7%>"/> 
</label> 
</span></td> 
</tr> 
«nu 
<tr> 


<td height="30" colspan="2" align="center" valign="middle" ><label> 
<input type="submit" name— "button" id— "button" value= "Wize" /> 
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</label> 
<label> 
<input type— "reset" name="button2" id="button2" value— "Ei" /> 
</label ></td> 
</tr> 
</table> 
</form> 
<!-- InstanceEndEditable --></td> 
</tr> 
<tr> 
<td height="30" align="center" bgcolor=" # FFCC66"— — span class= "STYLE12" ><a 
href= "bookadd. jsp" > Hf m AB </a></span></td> 
</tr> 
<tr> 
<td height="30" align="center" bgcolor=" € FFCC66">< span class="STYLE12" ><a 
href= "bookedit. jsp" > f& & AB </a ></span> </td> 
</tr> 
<tr> 
<td height="30" align="center" bgcolor=" # FFCC66">< span class=" STYLE12" ><a 
href= "bookdelete. jsp" > HM Al </a ></span> </td> 
</tr> 
<u> 
<td height="30" align="center" bgcolor=" # FFCC66" ><span class= "STYLE12"><a 
href= "bookquery. jsp" > # i] Al 3</a></span></td> 
</tr> 
<tr> 
<td height="40" class= "STYLE2"- iT i </td> 
</tr> 
<tr> 
<td height="40" class="STYLE2">2 i </td> 
</tr> 
<tr> 
<td height="30" align="center" bgcolor=" # FFCC66" class="STYLE12"># ifi 2 fà </td> 
</tr> 
<tr> 
<td height="30" align="center" bgcolor=" # FFCC66" class="STYLE12"> WRS R </td> 
</tr> 
<% 
GregorianCalendar d= new GregorianCalendar() ; 
String year= Integer. toString(d. get(Calendar. YEAR) ) ; 
String month= Integer. toString(d. get(Calendar. MONTH) +1); 
String day = Integer. toString(d. get(Calendar. DAY_OF_MONTH)); 
5 


<u> 
<td height="60" align=" center" ><span class="STYLE10" > #8 # A: <% = (String) 
session. getAttribute("username") % ><br /> 
BY [E] -< % = year% >-< % =month% >-< % = day% ></span></td> 
</tr> 


s> (semwmiss ae] 0000 


<u> 
<td height="30" align="center" ><a href="manage. jsp" 3E MEHR 1$ 9t </a></td> 
</tr> 
</table> 
<% 
// 获 取 表单 提交 数据 
String bookid= db. hzsb( request. getParameter("bookid")) ; 
String bookname= db. hzsb( request. getParameter("bookname")) ; 
String author— db. hzsb( request. getParameter( "author" ) ); 
String publisher— db. hzsb( request. getParameter( " publisher") ) ; 


String category — db. hzsb( request. getParameter("category")) ; 
String price— db. hzsb(request. getParameter(" price") ) ; 
String stock— db. hzsb(request. getParameter(" stock") ) ; 


String rssql =" UPDATE book SET name = '" + bookname + " ' , author = '" + author + 
"', publisher— '"+ publisher+"', type= '" +category+"', price='"+price+"', stock — '" + 
stock - "' WHERE id= '" 4- bookid-- " '" ; 
db. connection() ; 
/ / out. printIn(rssql) ; 
int rsn— db. update(rssql) ; 
if (rsn>0) 
response. sendRedirect( " bookedit. jsp") ; 
VL»: 
</body> 
<!-- InstanceEnd --></html> 


[bookquery. jsp} 
<%@ page contentType= "text/html; charset=gb2312" language= "java" import="java. sql. * , 
java. util. * " errorPage—"" 967» 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www. 
w3.org/ TR/ xhtmll/DTD/ xhtmll-transitional. dtd" > 
< html xmlns =" http://www. w3. org/1999/xhtml" > <!- - InstanceBegin template = 
"/Templates/mb. dwt. jsp" codeOutsideHTMLIsLocked-— "false" --> 
<head> 
<meta http-equiv— "Content-Type" content= "text/html; charset=gb2312" /> 
<!-- InstanceBeginEditable name= "doctitle" --> 
<title> X bs BC BE / title 
<!-- InstanceEndEditable --> 
<!-- InstanceBeginEditable name="head" --> 
<style type="text/css"> 
«vt 
.STYLE11 (font-size: 18px} 
--> 
</style> 
<!-- InstanceEndEditable --> 
<style type="text/css"> 
= 
.STYLE14 (color: # FF6600} 
.STYLE18 {font-size: 24} 
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--> 
</style> 
<style type="text/css"> 
<i- 
.STYLE10 (font-family: "宋体 "} 
.STYLE12 {font-family: Arial, Helvetica, sans-serif; font-size: 16px; } 
.STYLE2 {font-family: "XIF"; 
font-size: 24px; 
color: # FF9900; 
i 
-> 
</style> 
</head> 
<jsp:useBean id="db" class= "bean. mydb" scope="page"/> 
<body> 
<table width="900" border="0" align="center" cellpadding= "0" cellspacing= "0"> 
<tr> 
<td width="149" height— "40" — span class="STYLE2"> [8 45 4$ 38 — / span — /td 
< td width =" 751" rowspan =" 10" align =" center" valign =" top" > <!- - 
InstanceBeginEditable name= "EditRegionl" --> 
<form id— "form1" name="form1" method="post" action= "bookqueryl.jsp"— 
<table width— "500" border— "0" align="center" cellpadding— "0" cellspacing= "0"> 
<u> 
<td height =" 30" colspan="2" align="left" valign =" middle" bgcolor = 
"#CCCCCC" class="STYLE7" ><span class= "STYLE10 STYLE11"> 
<label> [8 3 E 38 » » # ifi] [8] B — / label 
</span></td> 
</tr> 
<tr> 
<td height =" 15" align =" right" valign =" middle" class =" STYLE7 STYLE8 
STYLE11 STYLE11 STYLE8"> 4$ ID: </td> 
<td height="30" align="left" valign="middle" ><input name = " bookid" type= 
"text" class="STYLE11" id="textfield" /></td> 
</a> 
<tr> 
<td height — " 30" align =" right" valign =" middle" class — " STYLE7 STYLES 
STYLE11 STYLE11 STYLE8"> [8 B 4 fj :</td> 
<td height="30" align="left" valign="middle" ><span class="STYLE10 STYLE11"> 
<label> 
<input type="text" name="bookname" id— "textfield2" /> 
</label> 
</span></td> 
</tr> 
<tr> 
<td height =" 30" align =" right" valign =" middle" class =" STYLE? STYLE8 
STYLE11 STYLE11 STYLE8" >% # :</td> 
<td height="30" align="left" valign="middle"><span class="STYLE10 STYLE11"> 
<label> 
<input type="text" name= "author" id— "textfield3" /> 
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</label> 
</span></td> 
</tr> 
<tr> 
<td height — " 30" align =" right" valign =" middle" class =" STYLE7 STYLE8 
STYLE11 STYLE11 STYLE8"> H fiit : </td> 
<td height="30" align="left" valign="middle"><span class="STYLE10 STYLE11"> 
<label> 
<input type="text" name= "publisher" id="textfield4" /> 
</label> 
</span> </td> 
</tr> 
<E 
<td height =" 30" align =" right" valign =" middle" class =" STYLE7 STYLE8 
STYLE11 STYLE11 STYLE8" > 4] : </td> 
<td height="30" align="left" valign="middle"><span class="STYLE10 STYLE11"> 
<label> 
<select name= "category" id= "select" > 
<option></option> 
<option> fH </option> 
<option> #%#</option> 
«option /E if </option> 
option tL Z — / option 
option f& 4 — / option 
<option> K ff — / option 
</select> 
</label> 
</span></td> 
</tr> 
<tr> 
<td height — "30" colspan="2" align="center" valign="middle" ><span class= 
"STYLE10"— 
label 
<input type="submit" name— "button" id— "button" value 一 "确定 " /> 
</label> 
<label></label> 
</span></td> 
</tr> 
</table> 
</form> 
<!-- InstanceEndEditable --></td> 
</tr> 
<u> 
<td height="30" align="center" bgcolor=" € FFCC66" ><span class= "STYLE12"><a 
href="bookadd. jsp" > ğ dn Al 3 </a></span></td> 
</tr> 
<tr> 
<td height="30" align="center" bgcolor=" # FFCC66">< span class= "STYLE12"><a 
href= "bookedit. jsp" > f& it RB </a ></span> </td> 
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</tr> 
<u> 
<td height="30" align="center" bgcolor=" # FFCC66"  — span class= "STYLE12"><a 
href= "bookdelete. jsp" BIER Bl </a ></span> </td> 
</tr> 
<tr> 
<td height="30" align="center" bgcolor=" # FFCC66">< span class="STYLE12" ><a 
href= "bookquery. jsp" ># ifi A B </a ></span> </td> 
</tr> 
<tr> 
<td height="40" class="STYLE2">i] ÁE </td> 
</tr> 
<tr> 
<td height="40" class="STYLE2">2 RE H</td> 
</tr> 
<tr> 
<td height="30" align="center" bgcolor=" # FFCC66" class="STYLE12"> # if] R </td> 
</tr> 
<tr> 
<td height="30" align="center" bgcolor=" # FFCC66" class="STYLE12"> Wi Ef: e: R </td> 
</tr> 
<% 
GregorianCalendar d= new GregorianCalendar() ; 
String year= Integer. toString(d. get(Calendar. YEAR)) ; 
String month= Integer. toString(d. get( Calendar. MONTH) +1); 
String day = Integer. toString(d. get(Calendar. DAY OF MONTH)); 
%> 


<tr> 
<td height —"60" align — " center" ><span class=" STYLE10" >$ fF Bi : <% = (String) 
session. getAttribute(" username") % ><br /> 
Bt [a]: <% = year% >-< % =month% >-< % = day% ></span> </td> 
</tr> 
<tr> 
<td height="30" align= "center" ><a href= "manage. jsp" >36 MEM A P$ 90 — / a7 — / td 
</tr> 
</table> 


</body> 
<!-- InstanceEnd --></html> 


[bookquery1. jsp] 


<%@ page contentType= "text/html; charset— gb2312" language="java" import="java. sql. * , 
java. util. * " errorPage— "" 267 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional// EN" "http://www. 
w3.org/ TR/ xhtmll/DTD/xhtmll-transitional. dtd" > 

<html xmlns = " http://www. w3. org/1999/xhtml" > <!- - InstanceBegin template = 
"/Templates/mb. dwt. jsp" codeOutsideHTMLIsLocked— "false" --> 

<head> 
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<meta http-equiv— "Content-Type" content— "text/html; charset=gb2312" /> 
<!-- InstanceBeginEditable name= "doctitle" --> 
<title># if] Ai </title> 
<!-- InstanceEndEditable --> 
<!-- InstanceBeginEditable name= "head" --> 
<style type="text/css"> 
<l-- 
.STYLE14 (color: # FF6600} 
.STYLE18 {font-size: 24} 
--> 
</style> 
<!-- InstanceEndEditable --> 
<style type="text/css"> 
<l-- 
.STYLE10 (font-family: "宋体 "} 
.STYLE12 (font-family: Arial, Helvetica, sans-serif; font-size: 16px; } 
.STYLE2 (font-family: "XTR"; 
font-size: 24px; 
color: # FF9900; 
) 
--> 
</style> 
</head> 
<jsp:useBean id="db" class 
<body> 
<table width="900" border="0" align="center" cellpadding= 
<tr> 
<td width="149" height="40" ><span class= "STYLE2"> [8 45 4$ #8</span></td> 
< td width =" 751" rowspan =" 10" align =" center" valign =" top" > <!- - 
InstanceBeginEditable name="EditRegion3" --> 
<form id="form1" name— "forml" method="post" action= ""> 
<table width="700" border="0" cellspacing="0" cellpadding="0"> 
<tr> 
<td height — "30" align="center" valign="middle" bgcolor =" # CCCCCC" > 
<span class 一 "STYLE10 STYLE18"> &nbsp; HË ID</span></td> 
<td height ="30" align="center" valign="middle" bgcolor =" # CCCCCC" > 
<span class="STYLE10 STYLE18">A 4% & nbsp; </span> </td> 
<td height — "30" align="center" valign="middle" bgcolor =" # CCCCCC" > 
<span class="STYLE10 STYLE18">fF# &nbsp;</span></td> 
<td height="30" align="center" valign="middle" bgcolor =" € CCCCCC" > 
"STYLEI0 STYLE18"> Hi fitt. &-nbsp;</span></td> 
<td height — "30" align="center" valign="middle" bgcolor =" # CCCCCC" > 
<span class 一 "STYLE10 STYLE18"> 5! &nbsp;</span></td> 
<td height — "30" align="center" valign="middle" bgcolor =" # CCCCCC" > 
<span class 一 "STYLE10 STYLE18"> fff &nbsp;</span></td> 
<td height="30" align="center" valign="middle" bgcolor =" € CCCCCC" > 
<span class 一 "STYLE10 STYLE18">F# &nbsp;</span></td> 
<td height ="30" align="center" valign="middle" bgcolor =" # CCCCCC" > 
<span class="STYLE18"></span></td> 


"bean. mydb" scope="page"/> 


" cellspacing= "0"> 


<span class 
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</tr> 
<% 
String id= db. hzsb( request. getParameter("bookid")) ; 
String bookname- db. hzsb( request. getParameter("bookname" )) ; 
String author— db. hzsb( request. getParameter( "author" )) ; 
String publisher— db. hzsb( request. getParameter(" publisher" ) ) ; 
String category = db. hzsb( request. getParameter("category") ) ; 
ResultSet rs=null; 
String sqls 一 "SELECT * FROM book WHERE id='"+id+"'OR name= '"+ 
bookname+"' OR author== "十 author 十 "' OR publisher= "+ publisher+"'OR type=' 
"-Fcategory- " '"; 
db. connection() ; 
rs— db. query(sqls) ; 
/ / out. println(sqls) ; 
while (rs. next()) 
( String sl=rs. getString(1) ; 
String s2— rs. getString(2) ; 
String s3— rs. getString(3) ; 
String s4— rs. getString(4) ; 
String s5— rs. getString(5) ; 
String s6— rs. getString(6) ; 
String s7 — rs. getString(7) ; 
%> 
<tr> 
<td height="30" align="center" valign="middle" ><span class="STYLE18"> 
<%=s1%></span></td> 
<td height="30" align="center" valign="middle" ><span class= "STYLE18"> 
<%=s2%></span></td> 
<td height="30" align="center" valign="middle" ><span class= "STYLE18"> 
<%=s3%></span></td> 
<td height— "30" align="center" valign="middle" ><span class= "STYLE18"> 
<%=st4%></span></td> 
<td height="30" align="center" valign="middle" ><span class= "STYLE18"> 
<%=s5%></span></td> 
<td height="30" align="center" valign="middle" ><span class= "STYLE18"> 
<%=s6 %></span></td> 
<td height="30" align="center" valign="middle" ><span class= "STYLE18" > 
<%=s7%></span></td> 


</u><% } %> 
</table> 
</form> 


<!-- InstanceEndEditable --></td> 
</tr> 
<tr> 
<td height— "30" align="center" bgcolor=" € FFCC66">< span class="STYLE12" ><a 
href= "bookadd. jsp" > 1 JIll FE] 45 — / a7 — / span </td> 
</tr> 
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<u> 
<td height="30" align="center" bgcolor=" # FFCC66" ><span class= "STYLE12"><a 
href= "bookedit. jsp" > #2 R </a ></span> </td> 
</tr> 
<u> 
<td height="30" align="center" bgcolor=" # FFCC66" ><span class= "STYLE12"><a 
href= "bookdelete. jsp" > BIER Bl </a></span></td> 
</tr> 
<tr> 
<td height="30" align="center" bgcolor=" # FFCC66" ><span class= "STYLE12"><a 
href= "bookquery. jsp" ># if] A </a></span></td> 
</tr> 
<tr> 
<td height="40" class="STYLE2">i] #4 </td> 
</tr> 
<tr> 
<td height="40" class="STYLE2">2 R FH</td> 
</tr> 
<tr> 
<td height="30" align="center" bgcolor=" + FFCC66" class="STYLE12"># if] fA </td> 
</tr> 
<tr> 
<td height="30" align="center" bgcolor=" # FFCC66" class="STYLE12"> WI BR fà </td> 
</tr> 
<% 
GregorianCalendar d= new GregorianCalendar( ) ; 
String year= Integer. toString(d. get(Calendar. YEAR) ) ; 
String month= Integer. toString(d. get( Calendar. MONTH) +1); 
String day= Integer. toString(d. get( Calendar. DAY OF MONTH)); 
%> 
<tr> 
<td height — "60" align — " center" ><span class =" STYLE10" >$ fF A : <% = (String) 
session. getAttribute( " username") % ><br /> 
BY [8] : <% = year% >-< % — month 4 >-< % = day% ></span></td> 
</tr> 
<tr> 
<td height="30" align="center" ><a href= "manage. jsp" >36 MEH R A </a></td> 
</tr> 
</table> 
</body> 
<!-- InstanceEnd --></html> 


[userregister. jsp] 


<% (à page contentType= "text/html; charset— gb2312" language— "java" import="java. sql. * " 
errorPage="" %> 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www. 
w3.org/ TR/ xhtmll/DTD/xhtmll-transitional. dtd" > 

<html xmlins— "http://www. w3.org/1999/xhtml"> 


<head> 
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<meta http-equiv— "Content-Type" content= "text/html; charset=gb2312" /> 
«itle Hl PEM </title> 
<style type="text/css"> 
<ih- 
.STYLE1 { 
font-family: "华文 新 魏 "; 
font-size: 24px; 
color: # FF9900; 
) 
.STYLE4 (font-family: "宋体 "; font-size: 18px; ) 
ML 
</style> 
</head> 
<jsp:useBean id— "db" class= "bean. mydb" scope="page"/> 
<body> 
<form id="form1" name="forml" method="post" action= ""> 


<table width="400" border="0" align="center" cellpadding="0" cellspacing="2" bgcolor 
="#CCCCCC"> 
<tr> 
<td height= "40" colspan="2" align="center" valign="middle" bgcolor=" € FFFFFF"> 
<span class="STYLE1" >H P! ÈM </span> </td> 
</tr> 
<tr> 
<td width="40%" height="30" align="center" bgcolor=" # FFFFFF" ><span class= 
"STYLE4"> HP% :</span> </td> 
<td height= "30" align="left" bgcolor=" # FFFFFF"><label> 
<input type="text" name= "username" id= "textfield" /> 
</label> </td> 
</tr> 
<tr> 
<td height= "30" align="center" bgcolor=" € FFFFFF" ><span class= "STYLE4"> 8f 
W :</span></td> 
<td height= "30" align="left" bgcolor=" # FFFFFF"><label> 
<input type="text" name= "password" id= "textfield2" /> 
</label ></td> 
</tr> 
<tr> 
<td height="30" align="center" bgcolor=" # FFFFFF">< span class=" STYLE4" > Mi 
UAB: </span> </td> 
<td height="30" align="left" bgcolor=" # FFFFFF"><label> 
<input type="text" name="confirmpassword" id 一 "textfield3" /> 
</label></td> 
</tr> 
<tr> 
<td height="30" align="center" bgcolor=" # FFFFFF">< span class= "STYLE4" >it 
4 :</span></td> 
<td height="30" align="left" bgcolor=" # FFFFFF"><label> 
<input type="text" name="name" id— "textfield4" /> 
</label ></td> 
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</tr> 
<u> 
<td height— "30" align="center" bgcolor=" # FFFFFF" ><span class= "STYLE4">t# 
Hl: </span></td> 
<td height— "30" align="left" bgcolor=" # FFFFFF"><label> 
<select name— "sex" id= "select" > 
option 5j </option> 
option? XX — / option 
</select> 
</label></td> 
</tr> 
<tr> 
<td height="30" align="center" bgcolor=" # FFFFFF">< span class="STYLE4"> ih 
dk :</span></td> 
<td height="30" align="left" bgcolor=" # FFFFFF"><label> 
<input type="text" name= "address" id— "textfield6" /> 
</label></td> 
</tr> 
<tr> 
<td height= "30" align="center" bgcolor=" # FFFFFF" ><span class= "STYLE4"> Mp 
4a: </span> </td> 
<td height="30" align="left" bgcolor=" # FFFFFF"><label> 
<input type="text" name= "code" id— "textfield7" /> 
</label></td> 
</tr> 
<tr> 
<td height="30" align="center" bgcolor=" # FFFFFF" ><span class= "STYLE4"> rf 
Wi: </span> </td> 
<td height="30" align="left" bgcolor=" # FFFFFF"><label> 
<input type="text" name= "tel" id— "textfield8" /> 
</label></td> 
</tr> 
<tr> 
<td height — "30" align="center" bgcolor =" # FFFFFF" ><span class=" STYLE4" > 
email: </span> </td> 
<td height="30" align="left" bgcolor=" # FFFFFF"><label> 
<input type="text" name= "email" id— "textfield9" /> 
</label></td> 
</tr> 
xu 
<td height— "30" colspan— "2" align="center" valign="middle" bgcolor=" # FFFFFF"> 
<label> 
<input type="submit" name =" button" id=" button" value=" li E" /> &nbsp; 
& nbsp; & nbsp; &-nbsp; 
</label> 
<label> 
<input type="reset" name="button2" id="button2" value— "SR Hi" /> 
</label></td> 
</tr> 
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</table> 

</form> 

<% 
String id= db. hzsb(request. getParameter("username")) ; 
String password— db. hzsb( request. getParameter( "password" ) ) ; 
String name— db. hzsb( request. getParameter(" name") ) ; 
String sex— db. hzsb(request. getParameter("sex")) ; 
String address— db. hzsb( request. getParameter( "address" ) ) ; 
String code= db. hzsb( request. getParameter(" code") ) ; 
String tel— db. hzsb( request. getParameter("tel")) ; 
String email— db. hzsb( request. getParameter( " email") ) ; 


if (id! — null && password! — null && name! —null && sex! — null 8.& address! = null 
&& code! — null && tel! — null & &. email! = null) 


String rssql= "insert into customer values(" 4- "V" dc id-d- "V" +", " 4- "V" 43- password d- "V 
"EU ION "name" H", "HN sex "V en," HV E address d- Vb" 
"EVI" code "VE", e reb "H", "H" "email" \ 1" +") "; 
db. connection() ; 
int rsn— db. update(rssql) ; 
if (rsn>0) 
response. sendRedirect(" . . /index. html") ; 
) 
%> 
</body> 
</html> 


[cartmanage. jsp] 


<%@ page contentType— "text/html; charset— gb2312" language— "java" import— "java. sql. * , 
java. util. * " errorPage="" 967 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www. 
w3.org/TR/xhtml1/DTD/xhtml1-transitional. dtd" > 
<html xmlns =" http://www. w3. org/1999/xhtml" > <!- - InstanceBegin template = 
"/Templates/cart. dwt. jsp" codeOutsideHTMLIsLocked= "false" --> 
<head> 

<meta http-equiv="Content-Type" content— "text/html; charset=gb2312" /> 

<!-- InstanceBeginEditable name= "doctitle" --> 

«itle ll] 45 — / title 

<!-- InstanceEndEditable --> 

<!-- InstanceBeginEditable name= "head" --> 

<style type="text/css"> 


«a. 
.STYLE14 (color: # FF6600} 
.STYLE18 {font-size: 24} 

€ 

</style> 


<!!-- InstanceEndEditable --> 
<style type="text/css"> 
«aee 
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.STYLE10 (font-family: "宋体 "} 
.STYLE12 {font-family: Arial, Helvetica, sans-serif; font-size: 16px; } 
.STYLE2 (font-family: "EXIF"; 

font-size: 24px; 

color: # FF9900; 


) 


body ( 


margin-left: Opx; 


margin-top: 0px; 


margin-right: Opx; 


margin-bottom: Opx; 


} 
--> 


</style> 


</head> 


<jsp:useBean id="db" class= "bean. mydb" scope="page"/> 


<body> 


<table width= "900" border="0" align="center" cellpadding= "0" cellspacing= "0"> 


<tr> 


<td width="149" height— "130"— — span class="STYLE2">< % =session. getAttribute(" 
username" ) % > 3KM JC Ifi AS P 35 35 WY F8] 435 — / span </td> 

<td width="751" rowspan="7" align="center" valign="top" ><!-- InstanceBeginEditable 
name="EditRegion3" -->&nbsp; 


<table width="700" border— "0" cellspacing="0" cellpadding= "0"> 


<tr> 
<td height —"30" align="center" valign="middle" bgcolor =" € CCCCCC" > 
<span class 一 "STYLE10 STYLE18">&-nbsp; [El 4$ ID</span></td> 
<td height = "30" align="center" valign="middle" bgcolor =" # CCCCCC" > 
<span class="STYLE10 STYLE18">A HAF &nbsp; </span> </td> 
<td height ="30" align="center" valign="middle" bgcolor =" # CCCCCC" > 
<span class 一 "STYLE10 STYLE18">{¢# &-nbsp;</span></td> 
<td height 30" align="center" valign="middle" bgcolor =" # CCCCCC" > 
<span class="STYLE10 STYLE18"> ih htt &nbsp;</span></td> 
<td height — "30" align="center" valign="middle" bgcolor =" # CCCCCC" > 
<span class="STYLE10 STYLE18">&-nbsp; E f£ — / span?^— /td7 
<td height — "30" align="center" valign="middle" bgcolor =" # CCCCCC" > 
<span class="STYLE10 STYLE18">&nbsp; fft ft </span> — /td^ 
<td height — "30" align="center" valign="middle" bgcolor =" # CCCCCC" > 
<span class="STYLE10 STYLE18"> iJ St &nbsp; </span><span class= 
"STYLE18"></span></td> 


</tr> 
<% 
ResultSet rs=null; 
db. connection() ; 
String query— "select * from book"; 
rs— db. query(query) ; 
while (rs.next()) 


( String sl=rs 
String s2—rs 


.getString(1) ; 
.getString(2) ; 
- getString(3) ; 
String s4— rs. getString(4) ; 
String s6— rs. getString(6) ; 
.getString(7) ; 


String s3=rs 


String s7=rs 


%> 


<tr> 
<td height="30" align="center" 
<%=s1%></span></td> 
<td height="30" align="center" 
<%=s2%></span></td> 
<td height="30" align="center" 
<%=s3%></span></td> 
<td height="30" align="center" 
<%=s4%></span></td> 
<td height="30" align="center" 
<%=s7%></span></td> 
<td height="30" align="center" 
<%=s6%></span></td> 


a 


<td height="30" align="center" 
</span> 
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valign="middle" ><span class="STYLE18"> 
valign="middle" ><span class= "STYLE18"> 
valign="middle" ><span class= "STYLE18"> 
valign="middle" ><span class= "STYLE18"> 
valign="middle" ><span class= "STYLE18"> 


valign="middle" ><span class= "STYLE18"> 


valign="middle" — span class= "STYLE18"> 


<form id="form1" name="form1" method="post" action=" purchase. jsp?id — 


<%=s1%>"> 


<label><input name= "amount" 


" type="text" id— "textfield" size— "5" /></label> 


<input type="submit" value— "lj 3C" name— "button2" /><span class= 
"STYLE10 STYLE18"> </span> 


</form> 
</td> 
</tr><% } 5 


</table> 


<!-- InstanceEndEditable --></td> 


</tr> 
<tr> 


<td height="50" align="center" bgcolor=" # FFCC66"><a href =" cartmanage. jsp" > 
<span class= "STYLE12" > B</span> </a></td> 


</tr> 
<tr> 


<td height="50" align="center" bgcolor=" # FFCC66"><a href="mycart. jsp" ><span 
class="STYLE12"> lj Wi 9 4E </span></a></td> 


</tr> 
<tr> 


<td height="50" align="center" bgcolor 


" # FFCC66"><a href — "orderdisplay. jsp" > 
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<span class= "STYLE12"># f iT #</span></a></td> 
</tr> 
<tr> 
<td height="50" align="center" bgcolor=" # FFCC66"><span class= "STYLE12" >f Bit 
it (a B</span></td> 
</tr> 
<% 
GregorianCalendar d=new GregorianCalendar( ) ; 
String year= Integer. toString(d. get(Calendar. YEAR) ) ; 
String month= Integer. toString(d. get(Calendar. MONTH) +1); 
String day = Integer. toString(d. get( Calendar. DAY_OF_MONTH)); 
%> 
<tr> 
<td height="40" class="STYLE2"><span class="STYLE10"><br /> 
</span> <span class= "STYLE12" > Hj fi]: <% = year% >-<% = month% >-<% = 
day% ></span></td> 
</tr> 
<tr> 
<td height="30" align="center" class="STYLE12"><a href= "cartmanage. jsp">i& M & 
RAR </a></td> 
</tr> 
</table> 
</body> 
<!-- InstanceEnd --></html> 


【purchase. jsp] 


<%@ page contentType= "text/html; charset=gb2312" language= "java" import= "java. sql. * " 
errorPage— "" % > 
<% Q page import= "java. util. * " 267 
<% Q page import— "bean. cart" 2677 
<html> 

<jsp:useBean id— "db" class— "bean. mydb" scope="page"/> 

<body> 

<% 
String bookid= request. getParameter("id") ; 


String num= request. getParameter( "amount" ) ; 
boolean match = false; // 是 否 购买 过 该 图 书 
Vector list= (Vector) session. getAttribute("cartList" ) ; 
cart cart=new cart(bookid, Integer. parseInt( num) ) ; 
ResultSet rs= null; 
int stock=0; 
db. connection() ; 
rs— db. query(" SELECT stock FROM book WHERE id= '"+bookid+""") ; 
while(rs. next()) 

stock= Integer. parseInt(rs. getString(1)) ; 
if (stock — Integer. parseInt(num)) ( 
if (list— — nul // 第 一 次 买书 

( 


list=new Vector() ; 


list. addElement(cart) ; 
) 
else // 不 是 第 一 次 买书 
{ 
for(int i—0;i- list. size) ;i ++) 
{ 
cart icart — (cart)list. elementAt(i) ; 
if (bookid. equals(icart. getBookId( )) ) 
{ 
icart. setNum(icart. getNum() + Integer. parseInt(num) ) ; 
list. setElementAt(icart, i) ; 
match= true; 
break; 
}// 计 结束 
) //for 结束 


if( ! match) 
list. addElement(cart) ; 
) // else 结束 


session. setAttribute( "cartList" , list) ; 
response. sendRedirect( " mycart. jsp"); 
) 
else{ 
out. printhn(" EFR Æ 1") ; 
) 
“> 
</body> 
</html> 


【mycart. jsp] 


=" ="; =" 


<% @ page contentType= "text/html; charset=gb2312" language= "java" import="java. sql. * , 
java.util. * " errorPage="" 267» 
<%@ page import— "bean. cart" %> 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www. 
w3.org/TR/xhtml1/DTD/xhtml1-transitional. dtd" > 
<html xmlns =" http://www. w3. org/1999/xhtml" > <!- - InstanceBegin template = 
"/Templates/cart. dwt. jsp" codeOutsideHTMLIsLocked= "false" --> 
<head> 
<meta http-equiv— "Content-Type" content= "text/html; charset=gb2312" /> 
<!-- InstanceBeginEditable name= "doctitle" --> 
<title> REA </title> 
<!-- InstanceEndEditable --> 
<!-- InstanceBeginEditable name="head" --> 
<style type="text/css"> 
s uri 
.STYLE19 (font-size: 18} 
-=> 
</style> 
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<!-- InstanceEndEditable --> 
<style type="text/css"> 
<l-- 
.STYLE14 {color: # FF6600} 
.STYLE18 {font-size: 24} 
--> 
</style> 
<style type="text/css"> 
«Te 
.STYLE10 (font-family: "宋体 "} 
.STYLE12 {font-family: Arial, Helvetica, sans-serif; font-size: 16px; } 
.STYLE2 (font-family: "4 C47 #8"; 
font-size: 24px; 
color: # FF9900; 
) 
body { 
margin-left: Opx; 
margin-top: Opx; 
margin-right: Opx; 
margin-bottom: Opx; 
} 
--> 
</style> 
</head> 
<jsp:useBean id— "db" class= "bean. mydb" scope="page"/> 
<body> 
<table width="900" border="0" align="center" cellpadding— "0" cellspacing="0"> 
<tr> 
<td width="149" height="130">< span class="STYLE2">< % = session. getAttribute 
("username") % > KIN JE ils AS FI 35 3k WY I B — / span» </td> 
<td width="751" rowspan= "7" align="center" valign="top" ><!-- InstanceBeginEditable 
name= "EditRegionl" --> 
<form id— "forml1" name— "forml" method="post" action= ""> 
<% 
String bookid= request. getParameter("id") ; 
String num— request. getParameter( "amount" ) ; 
if (( Vector) session. getAttribute( "cartList") = = null) { 
%> 
<p> E Bil Pi 4 8g 97 4 JE 25 </p> 
<% 
}else{ 
Vector list— ( Vector) session. getAttribute("cartList" ) ; 
int n=list. size() ; 
“> 
<table width="700" border="1" cellspacing= "0" cellpadding= "0"> 
<tr> 
<td height ="30" align="center" valign =" middle" ><span class =" STYLEIO 
STYLEM" >A 45 4 &</span></td> 
<td height — "30" align="center" valign =" middle" > < span class =" STYLEIO 
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STYLEM"— fE3f — / span? </td> 
<td height — "30" align="center" valign =" middle" ><span class =" STYLEIO 
STYLE14"> Hi Mł </span></td> 
<td height="30" align="center" valign =" middle" > < span class =" STYLEIO 
STYLE" ffr (3E) X /span2 </td> 
<td height — "30" align="center" valign =" middle" >< span class =" STYLEIO 
STYLE "— E </span> </td> 
<td height— "30" align="center" valign="middle" > &nbsp;</td> 
</tr> 
<% 
float money =0; 
for(int i=0;i<n;i+ +) 
{ 
cart c— (cart)list. elementAt(i) ; 
String sql =" SELECT id, name, author, publisher, price " +" FROM book 
WHERE id = '"+c. getBookId()+"'"; 
db. connection() ; 
ResultSet rs= db. query(sql) ; 
rs.next() ; 
// 取 出 记录 值 
String sl=rs. getString("id") ; 
String s2— rs. getString("name") ; 
String s3— rs. getString("author") ; 
String s4— rs. getString(" publisher") ; 
String s5 
String price s5; 


rs 


a 


- getString( " price") ; 


money+ — Float. parseFloat( price) * c. getNum() ; 
%> 

<tr> 
<td height="30" align="center" valign="middle" — % =s2% ></td> 
<td height="30" align="center" valign="middle" >< % =s3% ></td> 
<td height="30" align="center" valign="middle" >< % =s4% ></td> 
<td height="30" align="center" valign="middle" >< % =s5% ></td> 
<td height="30" align="center" valign="middle" >< % =c. getNum() % ></td> 
<td height="30" align="center" valign="middle" ><a href= "cartdelete. jsp? id 
=<%=sl%>">RAFE T </a> 
</td> 

</tr> 

<% }%> 

<tr> 
<td height="30" colspan="4" align="center" valign="middle" ><span class= 
"STYLE10 STYLE14" 之 你 所 选择 的 图 书 总 额 为 二 % = money% > 76 </span> 
</td> 
<td height="30" colspan= 
"STYLE10 STYLE14"> 


align="center" valign="middle" ><span class= 


<ahref =" order. jsp? money = < % = Float. toString (money) % > &username= < % = 
(String) session. getAttribute ( " username") % >" > # 28 iT 41 </a> </span> 
</td> 


[动态 网 站 设计 与 制作 一 -J5P ] 


</tr> 
<u> 
<td height="40" colspan="6" align="center" valign="bottom" ><span class= 
"STYLE10 STYLEI4"><a href=" cartclear. jsp" > iff 23 W Y 4 </a></span> 
</td> 
</tr> 
</table> 
<%}%> 
</form> 
<!-- InstanceEndEditable --></td> 
</tr> 
<tr> 
<td height="50" align="center" bgcolor=" € FFCC66"><a href="cartmanage. jsp" > 
<span class= "STYLE12" >W </span> </a></td> 
</tr> 
<tr> 
<td height —"50" align="center" bgcolor =" # FFCC66" ><a href =" mycart. jsp" > 
<span class="STYLE12"> Bf] W] 9] </span> </a></td> 
</tr> 
<tr> 
<td height="50" align="center" bgcolor=" # FFCC66"><a href= "orderdisplay. jsp" > 
<span class="STYLE12"># fi i] S </span> </a></td> 
</tr> 
<tr> 
<td height="50" align="center" bgcolor=" € FFCC66"><span class= "STYLE12"- f 
改 会 员 信息 二 /span 二 一 /td> 
</tr> 
<% 
GregorianCalendar d= new GregorianCalendar() ; 
String year= Integer. toString(d. get(Calendar. YEAR) ) ; 
String month= Integer. toString(d. get(Calendar. MONTH) +1); 
String day= Integer. toString(d. get(Calendar. DAY OF MONTH)); 
%> 
<tr> 
<td height="40" class— "STYLE2"- — span class="STYLE10"><br /> 
</span><span class= "STYLE12"> Hj [a] : < % = year% >-< % = month% >-< % = 
day% ></span></td> 
</tr> 
<tr> 
<td height= "30" align="center" class= "STYLE12"><a href="cartmanage. jsp" >3& [nl 
BRE R</a></td> 
</tr> 
</table> 
</body> 
<!-- InstanceEnd --></html> 


Corder. jsp] 


<%@ page contentType — "text/html; charset=gb2312" language= "java" import="java.sql. * " 947» 
<% (8 page import— "java. util. * "% > 
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<% @ page import= "bean. cart" % > 
<html> 
<jsp:useBean id= "db" class— "bean. mydb" scope="page"/> 
<body> 
<% 
int key=0; 
String id= 
String date= 
String money 


request. getParameter( "money" ) ; 
String user= request. getParameter( "username" ) ; 
// 获 得 日 期 格式 为 2011-5-1 
GregorianCalendar d= new GregorianCalendar() ; 
date= Integer. toString (d. get (Calendar. YEAR)) +"-" + Integer. toString (d. get (Calendar. 
MONTH) +1)+ 
"-"+ Integer. toString(d. get(Calendar. DAY_OF_MONTH)); 
// 查 询 数据 
String query 一 "SELECT * FROM userorder" ; 
db. connection() ; 
ResultSet rs— db. query(query) ; 
ifC!rs. next) 
{ 
key—1; —//userorder 中 没有 数据 ,也 就 是 没有 过 订单 , 则 id 设 为 1 
) 
else // 若 有 数据 取出 最 后 id, 再 加 1 
{ 
rs— db. query(query) ; 
while(rs. next() ) 
key — Integer. parseInt(rs. getString("id")) ; 
key 十 十 ; 
} 
// 获 取 id 值 ,订单 号 
id= Integer. toString(key) ; 
// 将 订单 中 的 信息 存储 到 orderlist 表 
Vector list= ( Vector) session. getAttribute("cartList") ; 
int n=list. size() ; 
out. println(n) ; 
for (int i=0;i<n;it+) 
{ 
cart cart= (cart) list. elementAt(i) ; 
String sqll="SELECT name, price FROM book WHERE 
id=" cart. getBookId() -" '" ; 
rs— db. query(sqll); 
rs.next() ; 
// 获 取 书 名 和 单价 
String name=rs. getString(" name") ; 
String price— rs. getString("price") ; 
// 将 订单 中 的 信息 存储 到 orderlist 表 
String sql2="INSERT INTO orderlist VALUES (" 十 "\ "十 id 十 "\ "十 "," 十 "\ "十 user 十 
et 
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// 测 试 语句 out. printIn(sql2) ; 

int rsn2— db. update(sql2) ; 

//if(rsn2>0) (out. printin("orderlist B ffi A") ;} ; 

// 从 book 表 中 , 减 去 用 户 购买 的 数量 

int stock=0; 

rs— db. query(" SELECT stock FROM book WHERE id= '"+ cart. getBookId()+"'"); 
while(rs. next() ) 
stock= Integer. parseInt( rs. getString(1)) ; 
// 购 买 数量 测试 语句 out. println(cart. getNum()) ; 
stock= stock-cart. getNum() ; 
// 所 剩 库 存 测试 语句 out. println(stock) ; 
String sql3— "UPDATE book SET stock="+"\'"+stock+"\'"++" WHERE id="+ 
"\'"+ cart. getBookId() +"\'""; 
//out. println(sql3) ; 
int rsn3=db. update(sql3) ; 

)//for 结束 
// 插 和 人 新 的 订单 到 userorder 表 
String sql="INSERT INTO userorder VALUES" +"\" +id+ "\" +", " 4- "V" user 
ENE MEN date t "Nn", "+ "V" 4 money + "V" 3") ; 
// 测 试 语句 out. println(sql) ; 
int rsnl = db. update(sql) ; 
response. sendRedirect( "orderdisplay.jsp") ; 
%> 
</body> 
</html> 


[orderdisplay. jsp] 


<%@ page contentType— "text/html; charset— gb2312" language— "java" import— "java. sql. * , 
java. util. * " errorPage—"" 967 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www. 
w3.org/ TR/ xhtmll1/DTD/ xhtmll-transitional. dtd" > 
<html xmlns =" http://www. w3. org/1999/xhtml" > <!- - InstanceBegin template = 
"/'Templates/cart. dwt.jsp" codeOutsideH TMLIsLocked— "false" --> 
<head> 
<meta http-equiv= "Content-Type" content="text/html; charset=gb2312" /> 
<!-- InstanceBeginEditable name= "doctitle" --> 
<title> JG bs Bl XC P4 — / title 
<!-- InstanceEndEditable --> 
<!-- InstanceBeginEditable name= "head" --> 
<style type="text/css"> 
«VY 
.STYLE19 (font-size: 18} 
--> 
</style> 
<!-- InstanceEndEditable --> 
<style type="text/css"> 
Sie 
.STYLE14 {color: # FF6600} 


.STYLE18 {font-size: 24} 
-=--> 
</style> 
<style type="text/css"> 
«M 
.STYLE10 (font-family: "宋体 "} 
.STYLE12 {font-family: Arial, Helvetica, sans-serif; font-size: 16px; 
.STYLE2 (font-family: "EXIF"; 
font-size: 24px; 
color: #FF9900; 


) 
body { 
margin-left: Opx; 
margin-top: Opx; 
margin-right: Opx; 
margin-bottom: 0px; 
) 
--> 
</style> 
</head> 
<jsp:useBean id="db" class= "bean. mydb" scope="page"/> 
<body> 
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) 


<table width— "900" border— "0" align="center" cellpadding— "0" cellspacing="0"> 


<tr> 


<td width="149" height="130">< span class="STYLE2" >< % = session. getAttribute 


("username") % > 3X itl Jé ilis AS Pd 34s 35k WY FI B </span> </td> 
<td width — "751" rowspan— "7" align="center" valign="top" ><!-- 
name= "EditRegionl" --> 


InstanceBeginEditable 


<table width— "700" border— "0" cellspacing— "0" cellpadding="0"> 


<tr> 


<td height —"30" align="center" valign =" middle" > < span class =" STYLE10 


STYLEM" i] #143 </span></td> 
<td height="30" aligi 
<td height="30" alig: 


"center" valign— "middle" Jl P! </td> 
"center" valign="middle" > #226 BY [8] </td> 


<td height — "30" align="center" valign="middle" >< span class — "STYLE10 


STYLE14"> li. #i</span></td> 


<td height ="30" align="center" valign="middle" ><span class ="STYLE10 


STYLE14">i#t#</span></td> 
</tr> 
<% 
String user— (String) session. getAttribute(" username") ; 


String query = " SELECT * FROM userorder WHERE username = 


“™+user+"'"; 
db. connection() ; 
ResultSet rs— db. query(query) ; 
while (rs. next()) 
{ 
String sl=rs. getString(1); 
String s2=rs. getString(2) ; 
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String s3=rs. getString(3); 
String s4— rs. getString(4) ; 
» 
<tr> 
<td height="30" align="center" valign="middle" ><span class ="STYLE14"> 
<%=sl %></span></td> 
<td height="30" align="center" valign="middle" — span class= "STYLE14"> 
<%=s2 %></span></td> 
<td height="30" align="center" valign="middle" ><span class= "STYLE14"> 
<%=s3 %></span></td> 
<td height="30" align="center" valign="middle" ><span class= "STYLE14"> 
<%=s4 %></span></td> 
<td height="30" align="center" valign="middle" ><span class= " STYLE14"— 
<a href="orderdetail. jsp?id=<%=s1%>" >##</a></span></td> 
</tr> 
<%}%> 
</table> 
<!-- InstanceEndEditable --></td> 
</tr> 
<tr> 
<td height="50" align — "center" bgcolor =" # FFCC66"><a href — " cartmanage. jsp" > 
<span class="STYLE12"> lj </span> </a></td> 
</tr> 
<tr> 
<td height="50" align="center" bgcolor=" # FFCC66"><a href — " mycart. jsp" ><span 
class= "STYLE12"> R AY lg 4] 4 </span> </a></td> 
</tr> 
<tr> 
<td height="50" align="center" bgcolor =" € FFCC66"><a href = "orderdisplay. jsp" > 
<span class="STYLE12"> Zt f iT #&</span></a></td> 
</tr> 
<tr> 
<td height— "50" align="center" bgcolor=" # FFCC66"><span class="STYLE12" > M 
2 DA fi A</span></td> 
</tr> 
<% 
GregorianCalendar d= new GregorianCalendar() ; 
String year= Integer. toString(d. get(Calendar. YEAR) ) ; 
String month = Integer. toString(d. get(Calendar. MONTH) 4-1); 
String day = Integer. toString(d. get(Calendar. DAY OF MONTH)); 
%> 
<tr> 
<td height="40" class="STYLE2">< span class="STYLE10"><br /> 
</span> < span class =" STYLE12" > R} [i] : <% = year% >-<% = month% >-<% = 
day% ></span> </td> 
</tr> 
<tr> 
<td height="30" align="center" class="STYLE12"><a href="cartmanage. jsp" > [n] 
RE R</a></td> 
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</tr> 
</table> 

</body> 
<!-- InstanceEnd --></html> 
[orderdetail. jsp] <% @ page contentType =" text/html; charset = gb2312" language =" java" 
import— "java. sql. * ‚java. util. * " errorPage—"" 267» 
<%@ page import— "bean. cart" %> 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www. 
w3.org/ TR/xhtmll/DTD/ xhtmll-transitional. dtd" > 


<html xmlns =" http://www. w3. org/1999/xhtml" > <!- - InstanceBegin template = 
"/Templates/cart. dwt. jsp" codeOutsideHTMLIsLocked-— "false" --> 
<head> 


<meta http-equiv— "Content-Type" content="text/html; charset—gb2312" /> 
<!-- InstanceBeginEditable name= "doctitle" --> 
<title> Ftp JB 3C Pj </title> 
<!-- InstanceEndEditable --> 
<!-- InstanceBeginEditable name="head" --> 
<style type="text/css"> 
<l-- 
.STYLE19 {font-size: 18} 
--> 
</style> 
<!-- InstanceEndEditable --> 
<style type="text/css"> 
<!-- 
.STYLE14 {color: # FF6600} 
.STYLE18 {font-size: 24} 
--> 
</style> 
<style type="text/css"> 
<!-- 
.STYLE10 (font-family: "宋体 "} 
.STYLE12 {font-family: Arial, Helvetica, sans-serif; font-size: 16px; } 
.STYLE2 (font-family: "XTR"; 
font-size: 24px; 
color: # FF9900; 
} 
body { 
margin-left: Opx; 
margin-top: Opx; 
margin-right: Opx; 
margin-bottom: Opx; 
) 
--> 
</style> 
</head> 
<jsp:useBean id="db" class= "bean. mydb" scope="page"/> 
<body> 
<table width="900" border= 


align="center" cellpadding= "0" cellspacing= 


> (mammis weise] 0000 


<tr> 
<td width="149" height="130"><span class= "STYLE2" ><% =session. getAttribute(" 
username") % > Xk i Jil 4 Fd 3 36 Wa FA B </span> </td> 
<td width="751" rowspan="7" align="center" valign="top" ><!-- InstanceBeginEditable 
name= "EditRegionl" --> 
<table width— "700" border— "0" cellspacing— "0" cellpadding="0"> 
<tr> 
<td height ="30" align="center" valign =" middle" ><span class =" STYLEIO 
STYLE14"> i] #43 </span></td> 
<td height ="30" align="center" valign =" middle" ><span class =" STYLEIO 
STYLE14">ĦP </span> </td> 
<td height ="30" align="center" valign =" middle" ><span class =" STYLEIO 
STYLEM" >A 4 &</span></td> 
<td height ="30" align="center" valign =" middle" ><span class ="STYLE10 
STYLE14"> S lit </span></td> 
<td height — "30" align="center" valign="middle" ><span class ="STYLE10 
STYLE14"> ft </span> </td> 
<td height =" 30" align="center" valign =" middle" ><span class =" STYLE10 
STYLE14"> ŠH (JG) </span> </td> 
</tr> 
<% 
String id= request. getParameter("id") ; 
//float money=0; 
db. connection() ; 
String sql "SELECT * FROM orderlist WHERE id= '"+id+"'"; 
ResultSet rs— db. query(sqD ; 


rs. next() ; 

String s1— rs. getString(1) ; // 订 单 号 
String s2— rs. getString(2) ; // 用 户 名 
//String s3=rs. getString(3) ; // 图 书 名 称 
//String s4=rs. getString(4) ; // 数 量 
String s5— rs. getString(5) ; // 总 额 
//String s6=rs. getString(6) ; // 单 价 


Vector list= (Vector)session. getAttribute("cartList" ) ; 
int n= list. size() ; 
//out. println(n) ; 
for(int i=0;i<n;it++) 
{ 
cart cart— (cart)list. elementAt(i) ; 
sgl— "SELECT name, price "十 "FROM book WHERE id= "+ cart. getBookId() +"; 
db. connection() ; 
rs— db. query(sql) ; 


rs. next() ; 
String s3— rs.getString(1) ; // 图 书 名 称 
String s4=rs. getString(2) ; // 单 价 
//out. println(sqD ; 

n 

<u> 


<td height="30" align="center" valign="middle">&nbsp;<%=sl %></td> 
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"30" align="center" valign="middle" > &nbsp; <% =s2 % ></td> 
<td height="30" align="center" valign="middle">&nbsp;<%=s3 % ></td> 
<td height="30" align="center" valign="middle" > &nbsp; < % = cart. getNum() %> 


</td> 
<td height="30" align="center" valign="middle" > &-nbsp; <% =s4 % ></td> 
<td height="30" align="center" valign="middle">&-nbsp;<% —s5 % ></td> 

</tr> 

<%} > 

</table> 
<!-- InstanceEndEditable --></td> 
</tr> 


<tr> 
<td height="50" align — "center" bgcolor =" # FFCC66"><a href =" cartmanage. jsp" > 
<span class= "STYLE12"> WH </span> </a></td> 
</tr> 
<tr> 
<td height="50" align="center" bgcolor=" # FFCC66"><a href ="mycart.jsp"> <span 
class= "STYLE12"> R WH 9] 4E. — / span? </a></td> 
</tr> 
<tr> 
<td height="50" align="center" bgcolor=" # FFCC66"><a href = "orderdisplay. jsp" > 
<span class— "STYLE12"7 Zt E i] Á — /span </a></td> 
</tr> 
<tr> 
<td height— "50" align="center" bgcolor=" # FFCC66"><span class="STYLE12" > it 
AA A B </span> </td> 
</tr> 
<% 
GregorianCalendar d=new GregorianCalendar() ; 
String year= Integer. toString(d. get(Calendar. YEAR) ) ; 
String month= Integer. toString(d. get(Calendar. MONTH) +1); 
String day= Integer. toString(d. get(Calendar. DAY_OF_MONTH)); 
%> 
<tr> 
<td height="40" class="STYLE2">< span class="STYLE10"><br /> 
</span> < span class =" STYLE12" > Bt [8] : <% = year% >-<% = month% >-< 96 = 
day% ></span></td> 
</tr> 
<tr> 
<td height="30" align="center" class="STYLE12"><a href= "cartmanage. jsp" > 8 M 2c 
员 首 页 </a></td>> 
</tr> 
</table> 
</body> 
<!-- InstanceEnd --></html> 


【cartclear. jsp] 


<%@ page contentType= "text/html; charset— gb2312" language="java" import="java. sql. * " 
errorPage="" 2477 
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<% @ page import— "java. util. * "% > 


<html> 
<body> 
<% 
Vector list= (Vector) session. getAttribute("cartList") ; 
list. removeAllElements() ; 
response. sendRedirect("mycart. jsp") ; 
%> 
</body> 
</html> 


[cartdelete. jsp] 


<% & page content Type — "text/html; charset— gb2312" language— "java" import— "java. sql. * " 9677 
«— (3 page import— "java. util. * "% > 
— (8 page import — "bean. cart" % > 
<html> 
<jsp:useBean id— "db" class— "bean. mydb" scope="page"/> 
<body> 
<% 
String bookid = request. getParameter("id") ; 
Vector list = (Vector)session. getAttribute("cartList") ; 
if (list= — null) 
{ 


System. out. println("Error!") ; 
) 
// 删 除 购买 图 书 
db. connection() ; 
for (int i=0; i<list.size(); i++) 
{ 
cart icart— (cart)list. elementAt(i) ; 
if (bookid. equals icart. getBookId( )) ) 
{ 
list. removeElementAt(i) ; 
break; 
) //if name matches 结束 


) // for 循环 结束 
response. sendRedirect("mycart.jsp"); 
%> 
</body> 
</html> 


Po 


page 指令 


page 指令 中 还 有 一 些 上 面 题目 中 没有 用 到 的 属性 也 为 大 家 做 一 下 介绍 。 

l. extends 属性 

该 属性 用 于 指明 Java 类 文件 超 类 全 名 。 使 用 该 属性 时 要 小 心 , 因 为 , 它 会 限制 ISP 
引擎 编译 文件 的 能 力 。 用 法 : extends— "package. class". 

2. session 属性 

该 属性 用 于 确定 JSP 页 面 是 否 使 用 HTTP session。 假 如 这 个 值 是 true, 则 session 
引用 的 是 当前 或 新 的 session。 假 如 这 个 值 是 false, 则 在 JSP 文件 中 ,不 能 使 用 session 对 
象 。 默 认 值 是 true。 用 法 : session="true| false". 

3. buffer 属性 

设置 buffer 缓冲 区 的 大 小 , 当 out 对 象 将 被 编译 的 JSP 页 面向 客户 Web 浏览 器 端 输 
出 时 使 用 。 它 的 默认 值 是 8kb。 假 如 你 指定 了 buffer 缓冲 区 的 大 小 ,这 个 输出 量 将 不 低 
于 你 指定 的 大 小 。 用 法 : buffer— "none|8kb| sizekb" 

4. autoFlush 属性 

该 属性 指出 : 当 缓冲 区 充满 时 .是 否 自动 刷新 。 如 果 值 为 true( 默 认 值 为 true). W A 
动 刷 新 ; 如 果 值 为 false, 则 当 缓冲 区 溢出 时 ,将 会 产生 错误 。 而 且 如 果 buffer 属性 的 值 设 
H none.autoFlush 属性 的 值 不 能 设 为 false。 用 法 : autoFlush— "true| false", 

5. isThreadSafe 属性 

假设 这 个 值 设 为 true, 多 个 线程 能 同时 访问 一 个 JSP 页 面 ; 假如 这 个 值 为 false, 对 一 
个 JSP 页 面 ,JSP 引擎 一 次 只 能 响应 一 个 用 户 的 请 求 。 默 认 值 为 true。 用 法 : 
isThreadSafe="true| false", 

6. info 属性 

关于 作者 、 版 本 和 著作 权 等 信息 ,可 以 通过 javax. sevlet. Servlet. getServletInfo ) 方 
法 查 到 该 信息 的 详细 情况 。 用 法 : info 二 "text"。 

7. errorPage 属性 

该 属性 用 于 设置 处 理 例外 事件 的 JSP 文件 的 路 径 名 。 假 如 这 个 路 径 名 以 “/” 开 始 ， 
则 这 个 路 径 名 是 对 ISP 应 用 文档 根 目录 而 言 的 ,而 且 由 Web 服务 器 决定 。 否 则 ,这 个 路 
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径 是 相对 于 当前 ISP 文件 而 言 的 。 用 法 : errorPage="relativeURL". 

8. isErrorPage 属性 

JSP 文件 是 否 显 示 错 误 页 面 。 如 果 这 个 值 为 true, 可 以 使 用 例外 exception 对 象 ; 如 
果 这 个 值 为 false( 默 认 值 也 为 false) ,在 JSP 文件 中 ,不 能 使 用 exception 对 象 。 用 法 : 
isErrorPage= "true| false" , 

Date 对 象 的 方法 

Date 对 象 的 方法 如 附 表 2-1 所 示 。 

附 表 2-1 Date 对 象 的 方法 


获取 日 期 和 时 间 的 方法 说 明 设置 日 期 和 时 间 的 方法 说 明 
getFullYear() sie Ha 位 数 表 示 的 setFullYear() vm 年 份 ,用 4 位 数 
getMonth() 返回 月 份 (0 一 11) setMonth() 设置 月 份 (0 一 11) 
getDate() 返回 日 数 (1 一 31) setDate() 设置 日 数 (1 一 31) 
getDay() 返回 星期 (0 一 6) setDay() 设置 星期 (0 一 6) 
getHours() 返回 小 时 数 (0 一 23) setHours() 设置 小 时 数 (0 一 23) 
getMinutes() 返回 分 钟 数 (0 一 59) setMinutes() 设置 分 钟 数 (0 一 59) 
getSeconds() 返回 秒 数 (0 一 59) setSeconds() 设置 秒 数 (0 一 59) 

et Time) 返回 Date 对 象 的 内 部 setTime() 使 用 毫秒 形式 设置 
上 毫秒 表示 Date 对 旬 
<input> pit 
写 人 标记 格式 如 下 : 


<input type 一 参数 name 二 参数 … > 
type 属性 值 如 附 表 2-2 所 示 。 
附 表 2-2 type 属性 值 列表 


属 性 输入 区 域 类 型 

单行 的 文本 输入 区 域 ,size 与 maxlength 属性 用 来 定义 此 种 输入 区 域 显 示 的 尺寸 大 小 
与 输入 的 最 大 字符 数 

普通 按钮 , 当 这 个 按钮 被 点 击 时 ,就 会 调用 属性 onclick 指定 的 函数 ;在 使 用 这 个 按钮 
button 时 ,一 般配 合 使 用 value 指定 在 它 上 面 显示 的 文字 ,用 onclick 指定 一 个 函数 ,一 般 为 
JavaScript 的 一 个 事件 

提交 到 服务 器 的 按钮 , 当 这 个 按钮 被 点 击 时 ,就 会 连接 到 表单 form 属性 action 指定 的 
url 地 址 

reset 重 置 按钮 , 单 击 该 按钮 可 将 表单 内 容 全 部 清除 ,重新 输入 数据 

一 个 复 选 框 ,checked 属性 用 来 设置 该 复 选 框 缺 省 时 是 否 被 选中 ,右边 示例 中 使 用 了 三 
个 复 选 框 

hidden 隐藏 区 域 ,用 户 不 能 在 其 中 输入 ,用 来 预 设 某 些 要 传送 的 信息 


text 


submit 


checkbox 


rM (mme 知识 字典 ] RE. 


BR 


属 性 输入 区 域 类 型 

使 用 图 像 来 代替 Submit 按钮 ,图 像 的 源 文 件 名 由 src 属性 指定 ,用 户 点 击 后 ,表单 中 的 
信息 和 点 击 位置 的 X、Y 坐标 一 起 传送 给 服务 器 

password | 输入 密码 的 区 域 , 当 用 户 输入 密码 时 ,区 域内 将 会 显示 " * "号 

单 选 按钮 类 型 ,checked 属性 用 来 设置 该 单 选 框 缺 省 时 是 否 被 选中 ,右边 示例 中 使 用 了 
三 个 单 选 框 


image 


radio 


< jsp: include zJJff: bs include 指令 之 间 存 在 的 差异 


二 jsp:include 记 动作 标识 与 include 指令 都 可 用 来 包含 文件 ,下 面 来 介绍 它们 之 间 存 
在 的 差异 。 

l. 属性 

include 指令 通过 file 属性 来 指定 被 包含 的 页 面 ,include 指令 将 file 属性 值 看 作 一 个 
实际 存在 的 文件 的 路 径 , 所 以 该 属性 不 支持 任何 表达 式 。 若 在 file 属性 值 中 应 用 JSP 表 
达 式 , 则 会 抛 出 异常 。 

二 jsp:include 二 动作 标识 通过 page 属性 来 指定 被 包含 的 页 面 ,该 属性 支持 ISP 表达 式 。 

2. 处 理 方式 

使 用 include 指令 被 包含 的 文件 , 它 的 内 容 会 原封 不 动 插入 到 包含 页 中 使 用 该 命令 的 
位 置 ,然后 JSP 编译 器 再 对 这 个 合成 的 文件 进行 编译 。 所 以 在 一 个 JSP 页 面 中 使 用 
include 指令 来 包含 另 一 个 JSP 页 面 ,最终 编译 后 的 文件 只 有 一 个 。 

使 用 二 jsp:include 二 动作 标识 包含 文件 时 , 当 该 标识 被 执行 时 ,程序 会 将 请 求 转发 到 
(注意 是 转发 ,而 不 是 请 求 重 定向 ) 被 包含 的 页 面 ,并 将 执行 结果 输出 到 浏览 器 中 ,然后 返 
回 包含 页 继续 执行 后 面 的 代码 。 因 为 服务 器 执行 的 是 两 个 文件 ,所 以 JSP 编译 器 会 分 别 
对 这 两 个 文件 进行 编译 。 

3. 包含 方式 不 同 

上 面 讲 到 使 用 include 指令 包含 文件 ,最 终 服 务 器 执行 的 是 将 两 个 文件 合成 后 由 JSP 
编译 器 编译 成 的 一 个 Class 文件 ,所 以 被 包含 文件 的 内 容 应 该 是 固定 不 变 的 , 若 改变 了 被 
包含 的 文件 , 则 主 文件 的 代码 就 发 生 了 改变 ,因此 服务 器 会 重新 编译 主 文 件 。include 指 
令 的 这 种 包含 过 程 称 为 静态 包含 。 

使 用 一 jsp:include 之 动作 标识 通常 是 来 包含 那些 经 常 需要 改动 的 文件 。 此 时 服务 器 
执行 的 是 两 个 文件 ,被 包含 文件 的 改动 不 会 影响 到 主 文件 ,因此 服务 器 不 会 对 主 文件 重新 
编译 ,而 只 需 重 新 编译 被 包含 的 文件 即 可 。 而 对 被 包含 文件 的 编译 是 在 执行 时 才 进 行 的 ， 
也 就 是 说 ,只 有 当 二 jsp:include 记 动作 标识 被 执行 时 ,使 用 该 识 包 含 的 目标 文件 才 会 被 编 
译 ,否则 被 包含 的 文件 不 会 被 编译 ,所 以 这 种 包含 过 程 称 为 动态 包含 。 


out 对 象 的 常用 方法 列举 如 下 


1. clear() 
此 方法 清除 缓冲 区 中 的 数据 ,并 不 输出 。 调 用 方法 如 下 : 
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out. clear() 


2. clearBuffer() 

此 方法 清除 缓冲 区 中 的 数据 ,并 把 清除 的 缓冲 区 中 的 数据 输出 到 客户 端 。 调 用 方法 
如 下 : 

out. clearBuffer() 

3. closeO 

此 方法 用 来 关闭 输出 流 。 因 为 out 对 象 实际 上 是 一 个 输出 流 。 调 用 方法 如 下 : 


out. close() 


4. flush() 
此 方法 输出 缓冲 区 中 的 数据 内 容 。 调 用 方法 如 下 : 
out. flush) 


5. getBufferSizeQ 
此 方法 得 到 缓冲 区 的 大 小 。 调 用 方法 如 下 : 


out. getBufferSize( ) 


6. getRemaining() 
此 方法 得 到 缓冲 区 中 未 被 使 用 空间 的 大 小 。 调 用 方法 如 下 : 


out. getRemaining() 


7. isAutoFlush() 
此 方法 是 否 是 自动 刷新 ,返回 的 是 一 个 布尔 值 。 如 果 是 自动 刷新 ,返回 true, 和 否则 返 
回 false。 调 用 方法 如 下 : 


out. isAutoFlush() 

8. newLine() 

此 方法 输出 一 个 换行 字符 。 调 用 方法 如 下 : 
out. newLine() 


9. print() 与 printlin() 
print() 与 printlin() 方 法 应 用 广泛 ,可 以 输出 各 种 类 型 的 数据 。 


request 对 象 
request 的 方法 主要 用 来 处 理 客户 端 浏 览 器 提交 请 求 中 的 各 项 参数 和 选项 。 主 要 方 
法 有 如 下 几 种 。 


1. getAttribute() 
此 方法 用 来 返回 指定 的 属性 值 ,如 果 不 存在 这 个 属性 ,返回 null 值 。 调 用 方法 如 下 : 


request. getAttribute(String str) 
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其 中 ,参数 str 是 指定 的 属性 的 名 称 。 

2. getAttributeNames() 

此 方法 返回 request 对 象 所 有 属性 的 名 称 , 其 返回 值 是 一 个 枚 举 类 型 的 对 象 。 调 用 
方法 如 下 : 

request. getAttributeNames() 

3. getContentLength() 

此 方法 获取 客户 端 提 交 的 所 有 信息 的 总 长 度 。 调 用 方法 如 下 : 

request. getContentLength() 

4. getCookie() 

此 方法 获得 客户 端的 Cookies 对 象 ,其 返回 值 为 一 个 Cookies 数组 。 调 用 方法 如 下 : 

request. getCookie() 


5. getHeader() 
此 方法 获取 HTTP 中 指定 的 头 名 称 值 。 调 用 方法 如 下 : 


request. getHeader(String str) 

6. getHeaders() 

此 方法 返回 指定 的 头 名 称 的 所 有 值 , 返 回 值 是 一 个 枚 举 类 型 的 对 象 。 调 用 方法 如 下 : 
request. get Headers(String str) 


其 中 ,参数 str 是 指定 的 头 名 称 。 

7. getHeadersName() 

此 方法 获得 request 的 头 中 属性 的 名 称 , 其 返回 值 是 一 个 枚 举 类 型 的 对 象 。 调 用 方 
法 如 下 : 


request. getHeadersName() 

8. getMethod() 

此 方法 获得 request 方法 . 如 get 或 post EI e 调用 方法 如 下 
request. getMethod() 

9. getParameter() 

此 方法 获得 指定 名 称 的 客户 端 提交 的 参数 值 。 调 用 方法 如 下 : 
request. getParameter( String str) 


其 中 ,参数 str 是 指定 的 参数 名 称 ,这 个 方法 是 JSP 程序 设计 中 最 为 常用 的 方法 
e 
10. getParameterNames() 


此 方法 获得 客户 端 提 交 的 参数 名 称 , 其 返回 值 是 一 个 枚 举 类 型 对 象 。 调 用 方法 如 下 : 
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request. getParameterNames() 


ll. getParameterValues() 


此 方法 获得 指定 客户 端 提交 


的 参数 值 。 调 用 方法 如 下 : 


Tequest. getParameterValues(String str) 


12. getProtocol() 


此 方法 得 到 客户 端 浏览 器 向 服务 器 端 发 送 数据 时 所 依据 的 协议 名 称 。 调 用 方法 


如 下 : 


request. getProtocol() 


13. getQueryString() 


此 方法 得 到 查询 字符 串 ,这 个 字符 串 是 客户 端 以 get 进行 传递 ,或 是 在 网 页 地 址 后 加 


上 参数 方法 得 到 的 。 调 用 方法 如 
request. getQueryString() 


14. getRequestURI() 


"m 


此 方法 获得 发 送 请 求 字符 串 的 客户 端 地 址 。 调 用 方法 如 下 ; 


request. getRequestURI() 


15. getRemoteAddr() 


此 方法 获得 客户 端的 IP 地 址 。 调 用 方法 如 下 : 


request. getRemoteAddr() 


16. getRemoteHost() 


此 方法 获得 客户 端的 机 器 名 称 。 如 果 得 不 到 名 称 则 获得 客户 端的 IP 地 址 。 调 用 方 


法 如 下 : 


request. getRemoteHost( ) 


17. getServerName() 


request. getServerName( ) 


18. getServletPath() 


request. getServletPath( ) 


19. getServerPort() 


request. getServerPort( ) 


此 方法 获得 服务 器 的 机 器 名 称 。 调 用 方法 如 下 : 


此 方法 返回 客户 端 请 求 页 面 的 文件 目录 。 调 用 方法 如 下 : 


此 方法 获得 服务 器 端 提供 HTTP 服务 的 端口 号 。 调 用 方法 如 下 : 
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Session 对 象 的 方法 


l. getAttribute() 
此 方法 获得 指定 的 session 对 象 。 调 用 方法 如 下 : 


session. getAttribute(String name) 


其 中 ,参数 name 是 指定 session 对 象 的 名 称 。 该 方法 返回 一 个 Object 对 象 ,任何 对 
象 都 可 加 入 到 session 对 象 中 ,因此 对 返回 的 对 象 要 用 强制 转换 的 方法 ,将 得 到 的 对 象 转 
换 为 此 对 象 原来 的 类 型 。 

2. getAttributeNames() 


此 方法 得 到 session 对 象 中 所 有 数据 名 称 的 枚 举 。 调 用 方法 如 下 : 
session. getAttributeNames() 


该 方法 返回 一 个 枚 举 类 型 的 对 象 ,可 以 用 返回 对 象 的 nextElements( ) 方 法 来 遍历 
session 对 象 中 所 有 的 数据 对 象 。 
3. getCrationTime() 


此 方法 得 到 session 对 象 创建 的 时 间 。 调 用 方法 如 下 : 
session. getCreationTime( ) 


此 方法 返回 一 个 long 类 型 的 值 ,单位 为 毫秒 ,是 从 1970 年 7 月 1 日 午夜 起 至 session 
对 象 创建 为 止 所 相隔 的 毫秒 数 。 

4. getId() 

此 方法 得 到 session 对 象 的 ID。 调用 方法 如 下 : 

session. getId() 

由 于 每 个 客户 端 与 服务 器 对 话 的 ID 不 同 ,因此 服务 器 通过 这 个 ID 来 区 分 不 同 的 
HP. 

5. getMaxInactivelterval() 


此 方法 获得 session 对 象 的 生存 时 间 ,返回 一 个 int 型 值 ,单位 是 秒 。 调 用 方法 如 下 : 


session. getMaxInactivelterval() 


6. getLastAccessedTime() 

此 方法 得 到 此 处 session 对 象 最 后 一 次 被 用 户 操作 的 时 间 ,单位 为 毫秒 ,是 从 1970 年 
7 H 1 日 午夜 起 至 session 对 象 最 后 一 次 被 操作 停止 所 相隔 的 毫秒 数 。 调 用 方法 如 下 : 

session. getLastAccessedTime() 

7. Invalidate() 

此 消息 使 session 对 象 失效 。 调 用 方法 如 下 : 


Session. Invalidate() 
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8. isNew() 
此 方法 判断 是 否 是 一 个 新 的 用 户 。 调 用 方法 如 下 : 


session. isNew() 


该 方法 返回 一 个 布尔 值 ,返回 true 表示 一 个 新 的 用 户 。 
9. removeAttribute() 
这 个 方法 用 来 从 session 对 象 中 删除 指定 的 session 对 象 。 调 用 方法 如 下 : 


session. removeAttribute( String name) 


其 参数 name 是 指定 的 session 对 象 的 名 称 ,该 方法 无 法 返回 值 。 
10. setAttribute() 
此 方法 用 来 设置 指定 session 对 象 中 数据 对 象 的 值 。 调 用 方法 如 下 : 


session. setAttribute(String name, object value) 


其 中 ,第 一 个 参数 name 指出 要 设置 的 session 对 象 中 数据 对 象 的 名 称 ; 第 二 个 参数 
value 使 这 个 对 象 的 对 应 值 。 如 果 指 定 的 对 象 不 存在 , 则 新 加 入 一 个 ; 如 果 已 存在 , 则 该 
值 会 被 更 改 。 

11. SetMaxInactivelnterval() 

此 方法 设置 session 对 象 生 产 的 时 间 。 调 用 方法 如 下 : 


session. SetMaxJnactiveInterval(int timecount) 

其 中 ,参数 timecount 指出 生存 的 时 间 ,单位 是 秒 ,该 方法 无 返回 值 。 
application 对 象 常用 方法 

l. getAttribute() 

此 方法 得 到 指定 的 application 对 象 在 数据 对 象 的 值 。 调 用 方法 如 下 : 


application. getAttractive(string name) 

2. getAttributeNames() 

此 方法 得 到 application 对 象 所 有 数据 对 象 的 一 个 枚 举 。 调 用 方法 如 下 : 
application. getAttributeNames() 


这 个 方法 返回 一 个 枚 举 类 型 的 对 象 ,可 以 用 返回 对 象 的 nextElements 方法 来 遍历 
application 对 象 中 所 有 的 数据 对 象 。 
3. getInitParameter() 


此 方法 返回 指定 的 application 对 象 中 数据 对 象 的 初始 值 。 调 用 方法 如 下 : 
application. getInitParameter() 


其 中 ,参数 name 是 指定 application 对 象 中 数据 对 象 的 名 称 。 
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4. getServletInfoO 
此 方法 返回 Servlet 编译 器 当前 的 版 本 信息 。 调 用 方法 如 下 : 


application. getServletInfo() 


5. setAttribute() 


此 方法 设置 指定 名 称 的 application 对 象 的 属性 值 。 调 用 方法 如 下 : 
application. setAttribute() 


其 中 ,第 一 个 对 象 name 是 指 application 对 象 中 数据 对 象 的 名 称 : 第 二 个 参数 object 
是 这 个 对 象 对 应 的 值 , 其 类 型 是 Object, 说 明 可 以 是 任意 类 型 ,如 果 对 象 不 存在 , 则 添加 该 
对 象 如 果 已 存在 则 将 其 覆盖 。 


习题 一 


一 、 选 择 题 
1. JSP 的 编译 指令 标记 通常 是 指 ( J 
A. Pag 指令 Include 指令 和 Taglib 指令 
B. Pag #4 „Include 指令 和 Plugin 指令 
C. Forward 指令 „Include 指令 和 Taglib 指令 
D. Pag 指令 .Include 指令 和 Taglib 指令 
2. 可 以 在 ( ) 标 记 之 间 插 入 Java 程序 片 。 
A. OLD B. <% 和 /二 C. </M%> D. <% 和 ! > 
8: € ) 不 属于 ISP 动作 指令 标记 。 


A. < jsp: param > B. < jsp:plugin > 

C. < jsp:useBean > D. < jsp:javaBean > 
4. JSP 的 Page 编译 指令 的 属性 Language 的 默认 值 是 ( — 2. 

A. Java Bac C; cs D. SQL 
5. JSP C  ”) 指 令 允 许 页 面 使 用 者 自 定义 标签 库 。 

A. Include B. Taglib C. Page D. Plugin 


6. 可 以 在 ( ””) 标 记 之 间 插 入 变量 与 方法 声明 。 

A. OBAT B. <%Al/> C. c/H 6n D. cf! > 
.能够 替代 二 字符 的 字符 是 ( D. 

A. & lt B. &gt C. &h D. &nbsp 
8. FRC  ) 注 释 为 隐藏 性 注释 。 

A. <! - -注释 内 容 [ 二 % = 表达 式 %>] - - 二 

B. <! - -注释 内 容 - - > 

C. 二 % - -注释 内 容 - - %> 

D. <!--[<% = 表达 式 % >] - - > 


- 
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9. 下 列 变量 声明 在 ( ) 范 围 内 有 效 。 


<%! Date dateTime; 
Int eountNum; 

%> 

A. 从 定义 开始 处 有 效 ,客户 之 间 不 共享 
B. 在 整个 页 面 内 有 效 ,客户 之 间 不 共享 
C. 在 整个 页 面 内 有 效 , 被 多 个 客户 共享 
D. 从 定义 开始 处 有 效 ,被 多 个 客户 共享 

10. 在 二 %! AIM > brik IB FAA Java 的 方法 称 为 页 面 的 成 员 方法 ,其 在 ( ) 范 


围 内 有 效 。 
A. 从 定义 处 之 后 有 效 B. 在 整个 页 面 内 有 效 
C. 从 定义 处 之 前 有 效 D. 不 确定 
11. 在 二 %! AM > brid Z E i ) ,可 以 直接 输出 其 值 。 
A. 变量 B. Java 表达 式 C. 字符 串 D. 数字 


12. include 指令 用 于 在 JSP 页 面 静态 插入 一 个 文件 ,插入 文件 可 以 是 JSP 页 面 、 
HTML 页 面 , 文 本 文件 或 一 段 Java 代码 ,但 必须 保证 插入 后 形成 的 文件 是 ( )。 
A. 是 一 个 完整 的 HTML 文件 B. 是 一 个 完整 的 JSP 文件 
C. 是 一 个 完整 的 TXT 文件 D. 是 一 个 完整 的 Java 源 文 件 
13. 当 一 个 客户 线程 执行 某 个 方法 时 ,其 他 客户 必须 等 待 ,直到 这 个 客户 线程 调用 执 
行 完毕 该 方法 后 ,其 他 客户 线程 才能 执行 ,这 样 的 方法 在 定义 时 必须 使 用 关键 字 ( Me 
A. public B. static C. synchronized D. private 
二 、 判 断 题 
1. 在 HTML 页 面 文件 中 加 入 JSP 脚本 元 素 、JSP 标记 等 就 构成 了 一 个 JSP 页 面 。 
( ) 
2. JSP 页 面 中 的 变量 和 方法 声明 (declaration) , 3€ 35 X (Expression) 和 Java 程序 片 


段 (Scriptlet) 统 称 为 JSP 标记 。 ( ) 
3. JSP 页 面 中 的 指令 标记 、JSP 动作 标记 统称 为 脚本 元 素 。 ( ) 
4. 在 二 %! AM > Rid H BOR Java 变量 在 整个 页 面 内 有 效 , 不 同 的 客户 之 间 
不 共享 。 ( ) 
5. 在 二 %! P> fal S BH AS Java 变量 在 整个 页 面 内 有 效 。 ( y 
6. 页 面 成 员 方法 不 可 以 在 页 面 的 Java 程序 片 中 调用 。 ( ) 
7. FU HER IR] T E" — 26 U RI 26 " Ze [8] 58 BH A 98 T Jk, a 28 t AS BE EIS Fe] A 
户 访问 页 面 的 线程 之 间 共 享 。 ( ) 
8. JSP 中 Java 表达 式 的 值 由 服务 器 负责 计算 ,并 将 计算 值 按 字 符 串 发 送 给 客户 
端 显示 。 ( ) 


9. 在 Java 程序 片 中 可 以 使 用 Java 语言 的 注释 方法 ,其 注释 的 内 容 会 发 送 到 客户 端 。 
( ) 


10. 不 可 以 用 一 个 page 指令 指定 多 个 属性 的 取 值 。 ( ) 
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11. jsp: include 动作 标记 与 include 指令 标记 包含 文件 的 处 理 时 间 和 方式 不 同 。 
( ) 


12. jsp: param 动作 标记 不 能 单独 使 用 ,必须 作为 jsp: include、jsp: forward 标记 等 


的 子 标记 使 用 ,并 为 它们 提供 参数 。 C 3J 


13. <jsp: forward.. 过 标记 的 page 属性 值 是 相对 的 URL 地 址 ,只 能 静态 的 URL. 


14. JSP 页 面 中 不 能 包含 脚本 元 素 。 ( ) 
15. Page 指令 不 能 定义 当前 ISP 程序 的 全 局 属性 。 ( ) 
三 、 填空 题 

1. 一 个 完整 的 JSP 页 面 是 由 普通 的 HTML 标记 、JSP 指令 标记 、JSP 动作 标记 、 变 


量 声明 与 方法 声明 、 i 7 种 要 素 构 成 。 


2. JSP 页 面 的 基本 构成 元 素 , 其 中 变量 和 方法 声明 (Declaration)、 表 达 式 


(Expression) fil Java 程序 片 (Scriptlet) 统 称 为 B 


是 ( 


3. 指令 标记 、JSP 动作 标记 统称 为 o 

4. JSP 页 面 的 程序 片 中 可 以 插入 标记 。 

5. 当 JSP 页 面 的 一 个 客户 线程 在 执行 方法 时 ,其 他 客户 必须 等 待 。 
6. JSP 页 面 中 ,输出 型 注释 的 内 容 写 在 和 之 间 。 

7. Page 指令 的 属性 Language 的 默认 值 是 o 

四 、 思 考题 

include 标记 与 include 动作 标记 有 什么 区 别 ? 

如 何 保证 页 面 跳 转 时 当前 页 面 与 跳 转 页 面 之 间 的 联系 ? 

如 果 有 两 个 用 户 访问 一 个 JSP 页 面 , 该 页 面 的 程序 片 将 被 执行 几 次 ? 
在 二 %! 和 铬 二 之 间 声 明 的 变量 和 在 二 % 和 名 过 之 间 声 明 的 变量 有 何 区 别 ? 
是 否 允 许 一 个 JSP 页 面 为 content Type 设置 两 次 不 同 的 值 ? 

JSP 的 特殊 字符 与 Java 语言 的 转 义 字符 有 何 关系 ? 

叙述 一 个 JSP 页 面 的 基本 组 成 。 
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一 、 选 择 题 
1. 下 面 不 属于 ISP 内 置 对 象 的 是 ( Ja 
A. out B. respone C. application D. page 
2. UFI ) 对 象 提供 了 访问 和 放置 页 面 中 共享 数据 的 方式 。 
A. pageContext B. response C. request D. session 
3. 调用 getCreationTime( ) 可 以 获取 session 对 象 创建 的 时 间 , 该 时 间 的 单位 
Je 
A. fb B. 分 秒 C. 毫秒 D. 微 秒 
4. 一 个 典型 的 HTTP 请 求 消息 包括 请 求 行 、 多 个 请 求 和 ( )。 
A. 响应 行 B. 信息 体 C. 响应 行 D. 响应 头 
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5. out 对 象 是 一 个 输出 流 ,其 输出 各 种 类 型 数据 并 换行 的 方法 是 ( OD. 


A. out. print() B. out. newLine() C. out. println D. out. write() 
6. out 对 象 是 一 个 输出 流 ,其 输出 不 换行 的 方法 是 ( ye 
A. out, print() B. out. newLine() C. out. println D. out. write() 
7. Form 表单 的 method 属性 能 取 下 列 ( ) 的 值 。 
A. submit B. puts C. post D. out 
8. 能 在 浏览 器 的 地 址 栏 中 看 到 提交 数据 的 表单 提示 方式 是 ( js 
A. submit B. get C. post D. out 
9. 可 以 利用 request 对 象 的 ( ) 方 法 获取 客户 端的 表单 信息 。 
A. request. getParameter() B. request. outParameter() 
C. request. writeParameter() D. request. handlerParameter() 
10. JSP 页 面 中 request. getParamter() 得 到 的 数据 ,其 类 型 是 ( Js 
A. Double B. int C. String D. Integer 
11. JSP 页 面 程序 片 中 可 以 使 用 ( ) 方 法 将 strNumx= request. getParamter("ix") 得 
到 的 数据 类 型 转换 为 Double 类 型 。 
A. Double. parseString(strNumx) B. Double. parseDpuble(strNumx) 
C. Double. parseInteger(strNumx) D. Double. parseFloat(strNumx) 
12. 下 面 不 属于 过 input 之 标记 中 的 name 属性 取 值 的 是 ( ) 。 
A. text B. radio C. checkbox D. picture 
13. 所 select> 用 于 在 表单 中 来 定义 下 列表 框 和 滚动 列表 框 空间 ,下 面 ( ) 属 性 指 
定 列表 框 默认 选项 。 
A. size B. value C. selected D. checked 
二 、 判 断 题 
1. Tomcat 服务 器 支持 直接 使 用 application MR. ( ) 
2. out 对 象 是 一 个 输出 流 , 它 实现 了 javax. servlet. JspWriter 接口 ,用 来 向 客户 端 输 
出 数据 。 C y 
3. 利用 response 对 象 的 sendRedirect 方法 只 能 实现 本 网 站 内 的 页 面 跳 转 , 但 不 能 传 
BER. C 2 
4. respone 对 象 主要 用 于 向 客户 端 发 送 数据 。 ( ) 


5. contentType 属性 用 来 设置 JSP 页 面 的 MIME 类 型 和 字符 编码 集 , 取 值 格式 为 
“MIME 类 型 ?或 “MIME 类 型 charset 二 字符 编码 集 ”,response 对 象 调用 addHeader 方 


法 修改 该 属性 的 值 。 € 3 
6. Post 属于 表单 的 隐 式 提交 信息 方法 。 C 2 
7. < select 二 标记 用 于 在 表单 中 插入 一 个 下 拉 菜 单 。 £ ) 
8. 表单 信息 的 验证 只 能 放 在 服务 器 端 执行 。 ( ) 
9. 网 页 中 只 要 使 用 GB2312 编码 就 不 会 出 现 中 文 乱码 。 ( ) 


10. 表单 提交 的 信息 就 封装 在 HTTP 请 求 消息 的 信息 体 部 分 .用户 使 用 request 对 
象 的 getParameter 方法 可 以 得 到 通过 表单 提交 的 信息 。 ( ) 
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11. request 对 象 的 getRemoteHost() 方 法 既 能 获取 客户 名 称 , 又 能 获取 客户 IP 

地 址 。 ( ) 
12. 同一 个 客户 在 同一 个 Web 服务 目录 中 的 session 对 象 是 相通 的 ,在 不 同 的 Web 

服务 器 目录 中 的 session 对 象 不 相同 。 ( ) 
13. session 对 象 是 HttpSession 接口 类 的 实例 ,由 客户 端 负责 创建 和 销毁 ,所 以 不 同 

客户 的 session 对 象 不 同 。 ( ) 
14. public long session。setMaxJnactiveInterval() 设 置 最 长 发 呆 时 间 ,单位 毫秒 。 

( ) 

15. session 对 象 可 以 用 来 保存 用 户 会 话 期 间 需 要 保存 的 数据 信息 。 ( ) 
16. application 对 象 对 所 有 用 户 都 是 共享 的 ,任何 对 它 的 操作 都 会 影响 到 所 有 的 

H^. C 2 
=. 填空 题 
1. out 对 象 的 方法 ,功能 是 输出 缓冲 的 内 容 。 

. JSP 的 对 象 用 来 保存 单个 用 户 访问 时 的 一 些 信 息 。 

.response 对 象 的 方法 可 以 将 当前 客户 端的 请 求 转 到 其 他 页 面 去 。 

. 当 客 户 端 请 求 一 个 JSP 页 面 时 ,JSP 容器 会 将 请 求 信息 包装 在 对 象 中 。 

. response, setHeader(“Rsfresh”,“5”) 的 含义 是 指 页 面 刷新 时 间 为 o 

. 表单 的 提交 方法 包括 和 方法 。 

. 通过 设置 Cookie 变量 的 属性 来 设置 他 的 生命 期 限 。 

四 、 思 考题 

. 请 简 述 ISP 中 常用 的 内 置 对 象 。 

. 简 述 request 对 象 和 response 对 象 的 作用 。 

. session 对 象 与 application 对 象 有 何 区 别 ? 

. 网 页 中 的 表单 如 何 定义 ,通常 表单 中 包含 哪些 元 素 ? 

.如何 处 理 表单 提交 的 汉字 ? 

. 一 个 用 户 在 不 同 的 Web 服务 目录 的 session 相同 吗 ? 

. 内置 对 象 的 4 个 作用 范围 是 什么 ? 什么 情况 下 session 会 关闭 ? 

. response. sendRedirect(URL url) 方 法 的 作用 是 什么 ? 

. 怎样 使 用 request, session 和 application 对 象 进 行 参数 存 取 ? 

. 什么 是 Cookie? 怎么 设置 和 获取 Cookie f? 


习 题 三 


BIPIN 


o ONAN eA WD 5- 


= 
o 


一 、 选 择 题 

1. 下 面 ( ) 不 是 JDBC 的 工作 任务 。 
A. 与 数据 库 建立 连接 
B. 操作 数据 库 ,处理 数据 库 返回 的 结果 
C. 在 网 页 中 生成 表格 
D. 向 数据 库 管理 系统 发 送 SQL 语句 
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2. 下 面 ( ARENAS oH BIE TTI. 
A. 通过 DriverManager. getConnection 方法 加 载 
B. 调用 方法 Class. forName 
C. 通过 添加 系统 的 jdbc. drivers 属性 
D. 通过 registerDriver 方法 
3. 关于 分 页 显示 ,下 列 的 叙述 ( ) 是 不 正确 的 。 
A. 只 编制 一 个 页 面 是 不 可 能 实现 分 页 显示 的 
B. 采用 一 个 至 三 个 页 面 都 可 以 实现 分 页 显示 
C. 分 页 显示 中 ,记录 集 不 必 在 页 面 跳 转 后 重新 生成 
D. 分 页 显示 中 页 面 显 示 的 记录 数 可 以 随 用 户 输入 调整 
4. DriverManager 类 的 getConnection(String url. String user. String password) 方 
法 中 ,参数 url 的 格式 为 jdbc: 去 子 协议 之 : <EM>. url 是 不 正确 的 。 
A. “jdbc; mysql://localhost:80/ 数 据 库 名 ” 
B.“jdbc:odbc: 数 据 源 ” 
C.“jdbc:oracle:thin@host: 端 口号 :数据库 名 ” 
D.“jdbc:sqlserver://172. 0. 0. 1:1443; DatabaseName 一 数据 库 名 ” 
5. 在 JDBC 中 ,( ”) 接 口 不 能 被 Connection 创建 。 


A. Statement B. PreparedStatement 

C. CallableStatement D. RowsetStatement 
6. 下 面 是 加 载 JDBC 数据 库 驱 动 的 代码 片段 : 

Try ( 


Class. forName("sun. jdbc. odbe. JdbcOdbcDriver") ; 
) 
Catch(ClassNotFoundException e) ( 
Out. print (e); 
) 
该 程序 加 载 的 是 ( ) 驱 动 。 
A, JDBC-ODBC 桥 连接 驱动 B. 部 分 Java 编写 本 地 驱动 
C. 本 地 协议 纯 Java 驱动 D. 网 络 纯 Java 驱动 
7. 下 面 是 创建 Statement 接口 并 执行 executeUpadate 方法 的 代码 片段 : 


Conn = DriverManager. getConnection ("jdbc:odbc:book",","); 

Stmt— conn. createStatement() ; 

String strsql— "insert into book values(" TP003', ‘ASP. NET", ' 李 ', ' 清 华 出 版 社 ',35)"; 
n = stmt.executeUpdate(strsql); 


代码 执行 成 功 后 n 的 值 为 ( ) 。 


A. 1 B. 0 C= D. 一 个 整数 
8. 下 列 代 码 中 rs 为 查询 得 到 的 结果 集 , 代 码 运行 后 表格 的 每 一 行 有 ( ) 个 单 


元 格 。 


while (rs. next( )){ 


Q (asmenis weise] 0 00 


out. print ("<tr>"); 
out. print("<td>"+ rs. getString(1) +"</td>"); 
out. print("<td>"+ rs. getString(2) +"</td>"); 
out. print("<td>"+ rs. getString(3) +"</td>"); 
out. print("<td>"+ rs. getString(" publish") +"</td>"); 
out. print("<td>"+ rs. getFloat("price") +"</td>"); 
out. print("</tr>"); 
) 


A. 4 B. 5 C. 6 D. 不 确定 
9. 查询 结果 集 ResultSet 对 象 是 以 统一 的 行列 形式 组 织 数据 的 ,执行 ResultSet 
rs —stmt, executeQuery(" select bid ，name . author ,publish . price from book"); i& 
句 , 得 到 的 结果 集 rs 列 数 为 ( do 
A. 4 B. 5 C. 6 D. 不 确定 
10. 下 列 代码 生成 了 一 个 结果 集 
Conn = DriverManager. getConnection (uri , user , password) ; 
Stmt = conn. createStatement (ResultSet. TPYE_SCROLL_SENSITIVE, 
ResultSet. CONCUR_ READ_ ONLY); 
rs— stmt. executeuery("select * from book"); 
下 面 对 rs 描述 正确 的 是 ( Ja 
A. 只 能 向 下 移动 的 结果 集 B. 可 上 下 滚动 的 结果 集 
C. 只 能 向 上 移动 的 结果 集 D. 不 确定 是 否 可 以 滚动 
11. 给 出 了 如 下 的 查询 条 件 字 符 串 String condition =" insert book values 
(?,?,?,?,?)"; 下 列 哪 个 接口 适合 执行 该 SQL 查询 ? ( ) 


A. Statement B. PrepareStatement 
C. CallableStatement D. 不 确定 
二 、 判 断 题 


1. JDBC 构建 在 ODBC 基础 上 ,为 数据 库 应 用 开发 人 员 数据库 前 台 工 具 开 发 人 员 
提供 了 一 种 标准 ,使 开发 人 员 可 以 用 任何 语言 编写 完整 的 数据 库 应 用 程序 。 ( ) 
2. JDBC 加 载 不 同 数据 库 的 驱动 程序 ,使 用 相应 的 参数 可 以 建立 与 各 种 数据 库 的 
连接 。 ( ) 
3. 应 用 程序 分 页 显示 记录 集 时 ,不宜 在 每 页 都 重新 连接 和 打开 数据 库 。 ( ) 
4. JDBC 中 的 URI 提供 了 一 种 标识 数据 库 的 方法 ,使 DriverManage 类 能 够 识别 相 


应 的 驱动 程序 。 ©) 
5. 进行 分 页 ,可 调用 JDBC 的 规范 中 有 关 分 页 的 接口 。 ( ) 
6. JDBC 的 URL 字符 串 是 由 驱动 程序 的 编写 者 提供 的 ,并 非 由 该 驱动 程序 的 使 用 
者 指定 。 œ 3 
7. ResultSet 结果 集 , 每 一 次 rs 可 以 看 到 一 行 , 要 在 看 到 下 一 行 ,必须 使 用 next() 方 
法 移动 当前 行 。 ( ) 


8. 如 果 需 要 在 结果 集中 前 后 移动 或 随机 显示 一 条 记录 ,这 时 就 必须 得 到 一 个 可 以 滚 
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动 的 结果 集 。 ( ) 
9. Statement 对 象 提 供 了 int executeUpdate (String sqlStatement) 方 法 ,用 于 实现 
对 数据 库 中 数据 的 添加 删除 和 更 新 操作 。 ( ) 
10. Statement 对 象 的 executeUpdate( String sqlStatement) 7j i£ '} . sqlStatement & 
数 是 由 insert, delete 和 update 等 关键 字 构 成 的 SQL 语句 。 ( ) 
三 、 填 空 题 
1. JDBC 的 英文 全 称 是 ,中 文 意义 是 。 


2. 简单 地 说 ,JDBC 能 够 完成 下 列 三 件 事 : 
3. JDBC 主要 由 两 部 分 组 成 : 一 部 分 是 访问 数据 库 的 高 层 接口 , 即 通常 所 说 的 
; 男 一 部 分 是 由 数据 库 厂商 提供 的 使 用 Java 程序 能 够 与 数据 库 连 接 通信 的 驱 
动 程序 , 即 
4. 目前 JDBC 驱动 程序 可 以 分 为 四 类 : 、 
5. 数据 库 的 连接 是 由 JDBC 的 管理 的 。 
6. 查询 结果 集 RseultSet 对 象 是 以 统一 的 行列 形式 组 织 数据 的 ,执行 RseultSet rs 一 


stmt, executeQuery("select bid , name , author . publish . price from book") ;语句 ,得 


到 结果 集 rs 第 一 列 对 用 ; 而 每 一 次 rs 只 能 看 到 行 , 要 再 看 到 下 一 行 , 必 
须 使 用 方法 移动 当前 行 。ResultSet 对 象 使 用 方法 获得 当前 行 字段 的 值 。 
7. stmt 为 Statement 对 象 ,执行 String sqlStatement ="delete from book where bid= 
"tp1001'" ; 语句 后 ,删除 数据 库 表 的 记录 需要 执行 语句 。 
四 、 思 考题 
1. 什么 是 JDBC 编程 接口 ? 
2. 试 列举 一 个 自己 在 编程 和 调试 中 碰 到 的 数据 库 问题 及 其 解决 办 法 。 
3. 如 何 实现 记录 集 的 行 操作 ? 
4. 进行 记录 定位 的 方法 有 哪些 ? 
5. 使 用 本 地 协议 纯 Java 驱动 操作 SQL Server 数据 库 的 步骤? 
6. 使 用 预 处 理 语句 和 存储 过 程 有 什么 好 处 ? 
7. 如 何 使 用 滚动 的 结果 集 ? 
习 题 四 
一 、 选 择 题 
l. JavaBean 可 以 通过 相关 ISP 动作 指令 进行 调用 。 下 面 ( ) 不 是 JavaBean 可 以 
使 用 的 ISP 动作 指令 。 
A. <jsp:useBean> B. <jsp:setProperty> 
C. <jsp:getProperty> D. <jsp:setParameter> 


2. 关于 JavaBean. ( ) BUR AS IE ff 
A. JavaBean 的 类 必须 是 具体 的 和 公共 的 :并且 具有 无 参数 的 构造 器 
B. JavaBean 的 类 属性 是 私有 的 ,要 通过 公共 方法 进行 访问 
C. JavaBean fil Servlet 一 样 ,使 用 之 前 必须 在 项 目的 web. xml 中 注册 
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D. JavaBean 属性 和 表单 控件 名 称 能 很 好 地 耦合 ,得 到 表单 提交 的 参数 
3. JavaBean 的 属性 必须 声明 为 private ,方法 必须 声明 为 ( ) 访 问 类 型 。 
A. private B. static C. protect D. public 
4. JSP 页 面 通过 ( ) 来 识别 Bean 对 象 , 可 以 在 程序 片 中 通过 xx. method 形式 来 
调用 Bean 中 的 set 和 get FH. 


A. name B. class C. id D. classname 
5. JavaBean 的 作用 范围 可 以 是 page. request, session Fil ( ) 四 个 作用 范围 中 的 一 种 。 
A. application B. local C. global D. class 


6. € ) 作 用 范围 的 Bean() ,请 求 响应 完成 则 该 Bean 即 被 释放 ,不 同 客 户 的 Bean 
互相 不 同 。 
A. application B. request C. page D. session 
d. ) 作 用 范围 的 BeanO ,被 Web 服务 目录 下 所 有 用 户 共享 ,任何 客户 对 Bean 
属性 的 修改 都 会 影响 到 其 他 用 户 。 
A. application B. request C. page D. session 
8. ( ) 作 用 范围 的 Bean, 当 客户 离开 这 个 页 面 时 ,JSP 引擎 取消 为 客户 该 页 面 分 
配 的 Bean, 释 放 他 所 占 的 内 存 空间 。 
A. application B. request C. page D. session 
9. 使 用 二 jsp: getProperty 二 动作 标记 可 以 在 JSP 页 面 中 得 到 的 Bean 实例 的 属性 
值 ,并 将 其 转换 为 什么 类 型 的 数据 ,发 送 到 客户 端 ( do 
A. String B. Double C. Object D. Classes 
10. 使 用 一 jsp:setProperty 二 动作 标记 可 以 在 JSP 页 面 中 设置 Bean 的 属性 ,但 必须 
保证 Bean 有 对 应 的 ( ) 方 法 。 
A. Setxxx B. setxxx C. getxxx D. Getxxx 
11. 使 用 格式 二 jsp: setProperty name = "beanid" propery =" bean 的 属性 " value = 
"二 % = expression 4% >"/> 4} Bean 的 属性 赋值 ,expression 的 数据 类 型 和 bean 的 属性 
类 型 ( Dis 
A. 必须 一 致 B. 可 以 不 一 致 C. 必须 不 同 D. 无 要 求 
12. Æ JSP 页 面 中 使 用 二 jsp:setProperty name = “beanid” property 一 ”bean 的 属 
TE" value 一" 字符 串 ”/ 二 格式 给 Long 类 型 的 Bean 属性 赋值 .会 调用 ( ) 数 据 类 型 转 
换 方法 。 


A. Long. parseLong(String s) B. Integer. parslnt (String s) 
C. Double. parseDouble (String s) D. 不 确定 

13. « ) 调 用 数据 类 型 转换 方法 会 发 生 NumberFormatException 一 场 。 
A. Long. parseLong("1234") B. Integer. parseInt("1234") 
C. Double. parseDouble("123. 45") D. Integer. parseInt("123a") 


14. Æ JSP 页 面 中 使 用 一 jsp:setProperty name — "bean 的 名 字 " property =" * " /二 格 
式 , 将 表单 参数 为 Bean 属性 赋值 .property = " * "格式 要 求 Bean 的 属性 名 字 ( Js 
A. 必须 和 表单 参数 类 型 一 致 B. 必须 和 表单 参数 名 称 一 一 对 应 
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C. 必须 和 表单 参数 数量 一 致 D. 名 称 不 一 定 对 应 
15. Æ JSP 页 面 中 使 用 二 jsp:setPropety name 一 "bean 的 名 字 " property =" bean 
属性 名 " param 一 "表单 参数 名 "/ 二 格式 ,用 表单 参数 为 Bean 属性 赋值 ,要求 Bean 的 属 


性 名 字 ( UM 
A. 必须 和 表单 参数 类 型 一 致 B. 必须 和 表单 参数 名 称 一 一 对 应 
C. 必须 和 表单 参数 数量 一 致 D. 名 称 不 一 定 对 应 
二 、 判断 题 
1. JavaBean 的 属性 可 读 写 ,编写 时 set 方法 和 get 方法 必须 配对 。 ( ) 
2. JavaBean 也 是 Java 类 ,因此 也 必须 有 主 函 数 。 ( ) 
3. JavaBean 组 建 就 是 Java 开发 中 的 一 个 类 ,通过 封装 属性 和 方法 称 为 具有 某 种 功 
能 和 接口 的 类 ,所 以 具有 Java 程序 的 特点 。 ( j 
4. Sun 公司 把 JavaBean 定义 为 一 个 可 重复 使 用 的 软件 组 件 , 类 似 于 电脑 CPU ,硬盘 
等 组 件 。 C ) 
5. JavaBean 分 为 可 视 化 组 建 和 非 可 视 化 组 建 。 ( 


) 
6. JavaBean 的 属性 必须 声明 为 private, 方 法 必须 声明 为 public 访问 类 型 。 ( ) 
7. 创建 JavaBean 要 经 过 编写 代码 ,编译 源 文件 ,配置 JavaBean 这 样 一 个 过 程 。 ( 
8. 在 JSP 页 面 中 调用 的 Bean 类 中 如 果 有 构造 方法 ,必须 是 public 类 型 且 必 有 参数 。 

( ) 
9. 布置 JavaBean 须 在 Web 服务 目录 的 WEB-INF\ classes 子 目录 下 建立 与 包 名 对 


应 的 子 目 录 ,并 将 字 节 文件 复制 到 该 目录 中 。 ( ) 
10. JavaBean 中 ,对 于 boolean 类 型 的 属性 ,可 以 使 用 is 代替 方法 名 称 中 的 set 和 get 
前 级 ,创建 Bean 必须 带 有 包 名 。 ( ) 
11. 在 JSP 页 面 中 使 用 Bean 首先 要 使 用 import 指令 将 Bean 引入 。 ( ) 
12. 修改 了 Bean 的 字 节 码 后 ,要 将 新 的 字 节 码 复制 到 对 应 的 WEB-INF \classes H 
录 中 ,重新 启动 tomcat 服务 器 才能 生效 。 ( 
13. 客户 在 某 个 页 面 修改 session 作用 范围 Bean 的 属性 ,在 其 他 页 面 ,该 Bean 的 属 
性 会 发 生 同 样 的 变化 ,不 同 客户 之 间 的 Bean 也 发 生变 化 。 ( ) 
14. fH —jsp:setProperty > aH fE trick. nT VA f Hl de 35 X ok FF BO Bean 的 属性 
赋值 。 C 2 


15. 使 用 格式 二 jsp:setProperty name =" beanid" property ="" bean 的 属性 " value= 
"字符 串 "/ 二 给 Bean 的 属性 赋值 ,这 个 字符 串 会 自动 被 转化 为 属性 的 数据 类 型 。 〈 


16. 表单 提交 后 ,一 jsp:setProperty 二 动作 指令 才 会 被 执行 。 ( ) 

三 、 填 空 题 

1. 在 Web 服务 器 端 使 用 JavaBean, 将 原来 页 面 中 程序 片 完 成 的 功能 封装 到 
JavaBean 中 ,这 样 能 很 好 地 实现 E 


2. JavaBean 中 用 一 组 set 方法 设置 Bean 的 私有 属性 值 , get 方法 获得 Bean 的 私有 
属性 值 。set 和 get 方法 名 称 与 属性 名 称 之 间 必 须 对 应 ,也 就 是 : 如 果 属 性 名 称 为 xxx, 那 
4 set 和 get 方 的 名 称 必 须 为 和 
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3. 用 户 在 实际 Web 应 用 开发 中 ,编写 Bean 除了 要 使 用 import 语句 引入 Java 的 标准 类 
外 ,可 能 还 需要 自己 编写 的 其 他 类 。 用 户 自己 编写 的 被 Bean 引用 的 类 称 为 

4. 创建 JavaBean 的 过 程 和 编写 Java 类 的 过 程 基本 相似 ,可 以 在 任何 Java 的 编程 环 
境 下 完成 X : a 

5. WH JavaBean 要 在 Web 服务 目录 的 WEB-INF/classes 文件 中 建立 与 
对 应 的 子 目录 ,用 户 要 注意 目录 名 称 的 大 小 写 。 

6. 使 用 Bean 首先 要 在 JSP 页 面 中 使 用 指令 将 Bean 引入 。 

7. 要 想 在 JSP 页 面 中 使 用 Bean. 必须 首先 使 用 动作 标记 在 页 面 中 定义 一 
个 JavaBean 的 实例 。 

8. scope 属性 代表 了 JavaBean 的 作用 范围 , 它 可 以 是 page、 、session 和 
application 四 个 作用 范围 中 的 任何 一 种 。 

四 、 思 考题 
. JavaBean 和 一 般 意义 上 的 Java 类 有 何 区 别 ? 
. 简 述 Bean 的 编写 方法 ,有 哪些 注意 要 点 。 
.如 何 实现 一 个 Bean 的 属性 与 表单 参数 的 关联 ? 
. 如 何在 页 面 的 程序 片 中 使 用 Bean? 
. WÈ request, session 和 application 有 效 范围 的 Bean 生命 周期 。 
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